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FEATURES 


Microcontroller interface 

m= Supports high-speed processors (e.g., 16-MHz 
8051, 16-MHz 68HC11) 

= Supports multiplexed/non-multiplexed address 
and data bus 

= Supports interrupt- or polled-processor interface 

u Provides microcontroller access to five external 
Switch settings 

@ Three-level power-down capability when idle, 
automatic power-up when command is received 

m= Supports host- and disk-interrupt pins 


Formatter Interface 

m Supports NRZ disk data rates up to 36 Mbits/ 

second 

Works with all disk encoding schemes 

Disk Interfaces supported include ST506/412, ESDI 

and SMD 

m Supports non-interleaved operations 

w User-modifiable RAM-based disk formatter con- 
trol store (31 x 4 bytes) 

w Multiple WCS branch and WCS data field branch 
Capability 

m Variable split data field support for constant-den- 
sity-recording formats 

m Full-track multi-sector transfer capability with no 
microcontroller intervention (cont) 
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OVERVIEW 


The CL-SH361 is a VLSI component that provides 
the majority of the hardware necessary to build a PC 
Winchester disk controller. Itis typically configured 
with buffer memory and a microcontroller — with 
system RAM and ROM — to create a complete 
intelligent PC Winchester disk controller. The 
device combines an advanced Winchester disk 
formatter, a dual-port buffer memory manager, and 
extensive hardware support, including direct bus 
connection with 24-mA drivers. Electrical noise is 
reduced on the IDE cable by staggered driver turn- 
on times. 


A static RAM (SRAM) buffer is controlled by the 
CL-SH361 memory manager. It supports disk data 
rates up to 36 Mbits/second, and simultaneously 
provides the handshake for PC-bus-programmed 
/O or DMA data transfer at rates up to 4 Mwords/ 
second. (cont.) 
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FEATURES (cont. 


Formatter Interface (cont.) 

Scheduled WCS access 

m User-programmable sector length up toa full track 

gm 16-bit CRC and 88-bit ECC polynomial with ‘on- 
the-fly’ hardware correction circuitry 

a Flexible sector-level defect handling 

= Buffer-derived ID field during format 

um Two Index timeout circuit for sector searches 

a Programmable read synchronization timeout 


Buffer Manager 

m Dual-port circular buffer contro! with access prior- 
ity resolver 

a Direct-buffer addressing up to 64K bytes of static 
RAM 

m Fixed and variable buffer segmentation support 

a Scheduled microcontroller write/read to/from 
buffer 

= Supports internal division of buffer clock by one, 
two, three and four for ease of Implementation 

a Supports buffer memory throughput to 12 Mbytes/ 
second 

a Provides host overrun control 

m Dual-buffer-chip enables for 64K buffers 


PC XT/AT and Other Compatible Interface 

m True real-time hardware and software 
compatibility with PC XT/AT and other compatible 
computers 

m Programmable polarity for host reset and inter- 
rupt lines for electrical compatibility with the 
PCMCIA interface 


CL-SH361 
PC XT/AT Disk Controller 


m Direct bus interface logic with on-chip 24-mA 
staggered turn-on time drivers 

B Supports 8- as well as 16-bit host bus transfer 

m= Supports any host speed with programmable and 
auto-wait-state generation 

@ PC XT/AT DMA handshake logic handles transfer 
to/from buffer memory at rates up to 4 Mwords/ 
second 

= Demand Mode DMA handshake logic (EISA Type 
‘B’) 

mu Buffer data transfer supported under DMA or 
programmed 1/0 for both PC XT and PC AT 

mu FIFOs provided to synchronize buffer RAM access 
with the PC bus and formatter 

m Emulates the IBM® task file for PC AT and IBM 
command descriptor block for PC XT 

@ Provides logic to speed-up command response 

m Provides logic for daisy-chaining two XT- or AT- 
embedded drives 

= Support of AT Master/Slave DASP* and PDIAG* 
Signals 

a Separate status for bus reset and host program 
reset 


Technology 
m 100-pin PQFP and VQFP packages 


m Advanced, low-power, double-metal CMOS 
technology 


OVERVIEW (cont.) 


The CL-SH361 Disk Formatter consists of a 
serializer/deserializer, a flexible RAM-based 
Sequencer, 16-bit CRC polynomial and an 88-bit 
Reed-Solomon ECC generator with on-the-fly hard- 
ware correction capability. The Formatter also 
supports variable split data fields for constant 
density recording formats. 


The CL-SH361 is designed to work with a local 
processor. lt has multiplexed or non-multiplexed 
address and data bus similar to that provided by the 
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Intel® 8051 and Motorola® 68HC1 1 family of control- 
lers. The local processor interface also supports 
separate host and disk interrupt pins. 


The CL-SH361 has a highly sophisticated power 
management capability. It supports four levels of 
power-down when idle in full support of the ATA 
Specification. The extremely low power require- 
ments of the CL-SH361 make it an ideal choice for 
laptop or other power-sensitive applications. 
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1. PIN INFORMATION 


1.1. Pin Diagram for the 100-Pin Plastic Quad Fiat Pack (PQFP) 
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1.2 Pin Diagram for the 100-Pin Very Low Profile Quad Fiat Pack (VQFP) 
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2. PIN ASSIGNMENTS 


The following conventions are used in the pin assignment table: (1) indicates an input; (O) indicates an 
output; (I/O) indicates an input/output; (OD) indicates an open-drain output; (Z) indicates a tri-state output 
or an input/output; (*) denotes a negative-true (active-low) signal. 


2.1. 100-Pin PQFP and VQFP Pin Assignments 


NOTE: Unless otherwise specified, a// references to pin locations include PQFP/VQFP pin numbers. 


PQFP VQFP 
Symbol No. No. Type Description 


BA15/CE2* 90 39 O BUFFER ADDRESS LINE 15/BUFFER CHIP ENABLE 2: Bit 
15 is for addressing buffer memory or the second 32K buffer 


chip enable. 

BA[14:0] 89-79 38-28 O BUFFER ADDRESS LINES: Bits 14-0 are for addressing buff- 
77-74 26-23 er memory. 

BD7/M/NM* 100 49 VO BUFFER DATA BUS/MULTIPLEXED/NON-MULTIPLEXED 


ADDRESS CONFIGURATION: This is Bit 7 of the 8-bit buffer 
data bus. The CL-SH361 is initialized to Multiplexed Mode if this 
input is connected to an external pull-up resistor (~20K ohm) 
after deassertion of the RST* Signal (Pin 34/83). Otherwise, it is 
configured in Non-multiplexed Mode. 


BD6/I/MC* 99 48 /O BUFFER DATA BUS/ INTEL/MOTOROLA: This is Bit 6 of the 
8-bit buffer data bus. The CL-SH361 is initialized to Motorola if 
this input is connected to an external pull-down resistor (~20K 
ohm) after deassertion of the RST* Signal (Pin 34/83). 
Otherwise, it is configured in intel Mode. 


BD5/IDE/ 98 47 VO BUFFER DATA BUS/IDE/PCMCIA CONFIGURATION: This 

PCMCIA* is Bit 5 of the 8-bit buffer data bus. The CL-SH361 is initialized 
for PCMCIA electrical compatibility if this pin is connected to an 
external pull-down resistor (~20K ohm) after the deassertion of 
the RST* Signal (Pin 34/83). Otherwise, it is configured to 
operate in the standard IDE Mode. The firmware can override 
this selection by writing to Bit 0 in the IDE/PCMCIA Control 


Register (Register 6FH). 

BD[4:0] 97-93 46-42 I/O BUFFER DATA BUS: These five signals are Bits 4-0 of the 8- 
bit buffer data bus. 

MOE* 1 50 O MEMORY OUTPUT ENABLE: This signal is asserted when a 


RAM Buffer Operation is active. It is recommended that MOE* 
be connected to the RAM Output Enable for high-speed 


operation. 
WE* 2 51 @) WRITE ENABLE: This signal is asserted when a buffer 


memory Write Operation is active. 


ES SS ETS TT I I I IT OE TIO 
pay AI DATA SHEET 2 


CL-SH361 
=== CIRRUS LOGIC Rebs ela 


| 


2.1. 100-Pin PQFP and VQFP Pin Assignments (cont.) 


PQFP VQFP 
Symbol No. No. Type Description 


CE1* 3 52 oO BUFFER CHIP ENABLE 1: This signal is the control signal for 
the full-buffer chip enable or the first 32K chip enable. 


INT*/ 4 53 0,OD INTERRUPT/DISK INTERRUPT: This is the microcontroller 

DISKINT* Interrupt*/Disk Interrupt* Pin, programmable for either push-pull 
or open-drain output circuitry. This pin contains an internal pull- 
up resistor. The INT*/DISKINT* pull-up can be disabled if the 
Interrupt Enable Bit (Register 77H, Bit 3) is set, and the Interrupt 
Pin Pull-up Disable Bit (Register 77H, Bit 4) is set. 


INPUT2/ 5 54 VO INPUT2/HOST INTERRUPT: This is the microcontroller Host 
HOSTINT* Interrupt* Pin, programmable for either push-pull or open-drain 
output circuitry. This pin can also be used as an edge-sensitive 
second input to the sequencer, and it contains an internal pull- 
up resistor that can be disabled by setting Bit 4 in Register 4FH. 


cs 6 55 | CHIP SELECT: This signal must be asserted to access the CL- 
SH361 registers. 


WR’*/R/W"* 7 56 | WRITE STROBE/READ/WRITE: When the intel bus control 
interface is selected (the /MC* Signal — Pin 99/48 is asserted), 
this acts as the WR* Signal. When the Write Strobe Signal is 
asserted and the CS Signal (Pin 6/55) is asserted, the data on 
the AD lines will be written to the specified register. 


When the Motorola bus control interface is selected (the /MC* 
Signal (Pin 99/48) is deasserted), this signal acts as the R/W* 
Signal. A high on this input, along with the RD*/DS Signal (Pin 
8/57) asserted and the CS Signal (Pin 6/55) asserted, it 
indicates a Read Operation. A low on this input, along with the 
RD*/DS Signal (Pin 8/57) asserted and CS Signal (Pin 6/55) 
asserted, indicates a Write Operation. 


RD*/DS 8 57 | READ STROBE/DATA STROBE: When the Intel bus control 
interface is selected (the /MC* Signal — Pin 99/48 is asserted), 
this signal acts as the RD* Signal. When the Read Strobe Signal 
is asserted and the CS Signal (Pin 6/55) is asserted, the data 
from the specified register will be driven onto the AD lines. 


When the Motorola bus control interface is selected (the /MC* 
Signal — Pin 99/48 is deasserted), this signal acts as the Data 
Strobe Signal. A high on this input, along with the WR*/R/W* 
Signal (Pin 7/56) asserted and the CS Signal (Pin 6/55) 
asserted, indicates a Read Operation. A high on this input, 
along with the WR*/R/W* (Pin 7/56) deasserted and the CS 
Signal (Pin 6/55) asserted, indicates a Write Operation. 
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2.1. 100-Pin PQFP and VQFP Pin Assignments (cont.) 
PQFP VQFP 

Symbol No. No. Type Description 

A[7:0] 9-16 65-58 I/O LOCAL MICROCONTROLLER ADDRESS BUS: These are 
non-multiplexed address input or demultiplexed address output 
lines. 

AD[7:0] 18-25 74-67 I/O LOCAL MICROCONTROLLER ADDRESS/DATA: These are 
tri-state address/data lines that interface with a multiplexed 
microcontroller address/data bus. 

ALE 26 75 | ADDRESS LATCH ENABLE: In Multiplexed Mode, this signal 
will latch the address from the AD bus; A[7:0} are the latched 
address outputs. When Non-multiplexed Mode is selected, this 
signal should be driven high, and A[7:0] are the demultiplexed 
address inputs. 

PDIAG* 27 76 VO PASS DIAGNOSTICS: This signal is used between two 
embedded AT drives for communicating drive diagnostic 
results. This pin contains an internal pull-up resistor that can be 
disabled by setting Bit 4 in Register 4FH. 

1FCLK/DASP* 28 77 VO 1FCLK/SLAVE PRESENT: The 1FCLK can be used for the 
ECC corrector circuit. For embedded AT drives, this pin can 
also function as the Slave Present Signal. This pin contains an 
internal pull-up resistor which can be disabled by setting Bit 4 in 
Register 4FH. 

INPUT1/ 31 80 VO INPUT1/OUTPUT: The state of this pin is sampled by reading 

OUTPUT Register 7DH, Bit 2. It is also a branch input to the sequencer 
RAM. When the pin is programmed to be an output, it is 
controlled by Bit 2 of the Control Field (AOH-BEH) of the 
Sequencer WCS RAM. This pin contains an internal pull-up 
resistor. The resistor is disabled when the pin is configured as 
an output. 

INDEX 32 81 | INDEX: This is an input for the index pulse received from the 
drive. 

WAM*/ 33 82 V/O WRITE ADDRESS MARK/ADDRESS MARK DETECT/ 

AMD*/ SECTOR: This signal can be configured to operate in Hard or 

SECTOR Soft Sector Mode by initializing the Hard/Soft* Sector Mode 


Control Bit of the Formatter Mode Selection Register (Register 
77H, Bit 7). The default is Soft Sector Mode. In Soft Sector 
Mode, when the RG Signal (Pin 35/84) is asserted, a low-level 
input on this signal indicates Address Mark detected. Also, in 
Soft Sector Mode, a 1-bit wide pulse is an output when WG 
(Pin 36/85) is active and an address mark is to be written. In 
Hard Sector Mode, this is the input for the sector pulse. 
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2.1. 100-Pin PQFP and VQFP Pin Assignments (cont.) 


PQFP VQFP 
Symbol No. No. Type Description 
RST* 34 83 l RESET: When this signal is asserted, it stops all operations 


within the chip and deasserts the RG Signal (Pin 35/84), the WG 
Signal (Pin 36/85), and the NRZ Signal (Pin 38/87). All I/O 
signals and host outputs are set to a high-impedance state. See 
Section 3.6, Register Initialization. 


Dv 
G) 


35 84 O READ GATE: This signal is asserted when the CL-SH361 is 
reading NRZ data from the storage device. 


WG 36 85 Oo WRITE GATE: This signal is asserted when the CL-SH361 is 
writing NRZ data to the storage device. 


RRCLK 37 86 | READ REFERENCE CLOCK: This is a multiplexed input 
sourced from the VFO oscillator during a Read Gate; otherwise, 
it is from the write oscillator. This is the primary clock for the 
Formatter section and must be present at all times, including 
during a Reset Operation. 


RZ 38 87 VO NRZ: This is a Read Data Input from the disk when the RG 
Signal (Pin 35/84) is active; this is a Write Data Output to the 
disk when the WG Signal (Pin 36/85) is active. 


2 


BCLK 39 88 I BUFFER CLOCK: This is a clock input that is used to generate 
buffer memory access cycles. 


1OCS16* 40 89 OD 16-BIT DATA TRANSFER: This signal indicates that a 16-bit 
data transfer is active on the PC bus. 


HINT/HINT* 41 90 O,Z HOST INTERRUPT: This signal, when enabled, sends an 
interrupt to the PC host. For PCMCIA electrical compatibility, 
this signal can be configured as active-iow. The polarity of this 
signal can be chosen at power-up by the state of the BD5/IDE/ 
PCMCIA Signal (Pin 98/47), or the firmware can select the 
output polarity by writing to Bit 0 in the IDE/PCMCIA Control 


Register (Register 6FH). 
HA[2:0] 43-45 92-94 | PC BUS ADDRESS LINES: The address lines HA[9,2:0] 


address the various AT/XT Control, Status, and Data Registers. 
Only the HA[1:0] lines are used for PC XT operation. 
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2.1. 100-Pin PQFP and VQFP Pin Assignments (cont.) 


PQFP VQFP 
Symbol No. No. Type Description 


HA9/HCS1* 46 95 | PC ADDRESS LINE 9 or CHIP SELECT 1: This is a 
Multiplexed Input Signal. When the HCS1 Mode Enable Bit 
(Register 52H, Bit 3) is reset, this input is PC Address Line 9; 
when the bit is set, the input is Host Chip Select 1. When this 
signal is configured as HCS1*, this input is ignored when the 
DACK* Signal (Pin 50/99) is asserted. This pin contains an 
internal pull-up resistor that can be disabled by setting Bit 4 in 
Register 4FH. 


HCS0* 47 96 | CHIP SELECT 0: When this signal is asserted, this input 
selects access to the Control, Status and Data Registers. This 
input is ignored during DMA data transfers, i.e., when the 
DACK* Signal (Pin 50/99) is asserted. This pin contains an 
internal pull-up resistor. It can be disabled by setting Bit 4 in 
Register 4FH. 


IOCHRDY* 48 97 oO 1/0 CHANNEL READY: This signal is asserted to extend host 
transfer cycles when the controller is not ready to respond. 


DREQ 49 98 O,Z DMA REQUEST: The DMA Request Signal is used during DMA 
transfer between the host and controller. This signal is issued by 
the controller to start a DMA transfer. 


DACK* 50 99 | DMA ACKNOWLEDGE: The DMA Acknowledge Signal is used 
during DMA to complete the DMA handshake for data transfer 
between the host and the CL-SH361. The signal is active for 
each transfer on the host bus. This pin contains an internal pull- 
up resistor. 


IOR* 51 100 /O READ STROBE: This signal is asserted by the host during 
a Host Read Operation. When this signal is asserted with the 
HCS0*/HCS1* or the DACK* Signal, it enables status or data 
onto the host data bus. 


lOw* 52 1 I 1/O WRITE STROBE: This signal is asserted by the host during 
a Host Write Operation. When this signal is asserted with the 
HCS0*/HCS1* or the DACK* Signal, data from the host data bus 
is strobed into the CL-SH361. 
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2.1. 100-Pin PQFP and VQFP Pin Assignments (cont.) 
PQFP VQFP 
Symbol No. No. Type Description 
HRST*/HRST 53 2 | HOST RESET: When this signal is asserted, it initializes the 
Control/Status Registers and stops any command in process. 
See Section 3.6, Register Initialization. This pin contains an 
internal pull-up resistor. For PCMCIA electrical compatibility, 
this signal can be configured as active-high. The polarity of this 
signal can be chosen at power-up by the state of the BD5/IDE/ 
PCMCIA Signal (Pin 98/47), or the firmware can select the 
output polarity by writing to Bit O in the IDE/PCMCIA Control 
Register (Register 6FH). 
HDB[15:0] 54-57, 3-6, 1/0,2 HOST DATA BUS: During PC AT operations, HDB[15:8] are 
59-62, 8-11 used in conjunction with HDB[7:0] for word transfers between 
65-68 14-17 the sector buffer and the host; Bits HDB[7:0] are used for contro! 
70-73 19-22 status and ECC byte access. During PC XT operation, only 
HDB[7:0] lines are used; the HDB[15:8] lines are tri-stated. 
HGND 58, 64, 7,13 HOST GROUND. 
69 18 
BGND 78,92 27,41 BUFFER BUS GROUND. 
LGND 17,30, 66, 79 LOGIC GROUND. 
42 91 
+5V 29,91, 12,40 POWER SUPPLY (+5) 
63 78 
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3. REGISTER TABLES 


3.1. Buffer Manager Registers 


Address Type* Description/Function 

9FH/BFH R/W Buffer Start Address 

DFH/FFH R/W Buffer End Address 

68H RW Scheduled Microcontroller Buffer Data Access 
53H R/W Buffer Transfer Control 

54H RAW Buffer Size/Segment Address 

59H RAW Buffer/PC Reset Register 

5AH-5BH R/W Disk Address Pointer 

5CH-5DH R/W Host Address Pointer 

5EH-5FH R/W PC Stop Pointer 

70H R/W Microcontroller Buffer Access 

73H Ww Auto-Command ‘Lock’ Release: A write to this register unlocks the 


Buffer Manager Registers that were locked when the host issued an 
Auto-Command, i.e., Registers 53H, 5C-5FH, 68H and 70H. If the firm- 
ware has used the Local Microcontroller Power-Down Bit (Register 
4FH, Bit 5), it will also be unlocked. 


3.2. PC Interface Registers 


Address Type Description/Function 

40H-47H RAW PC Interface Register File: These registers are for communication be- 
60H-67H tween the host PC and the local processor. 

55H-57H RAW PC Interface Registers 

50H R/W PC Interrupt Status Register 

51H RW PC Interrupt Enable Register 

52H R/W Miscellaneous Control/Status Register 

58H RAW PC Mode Control Register 

6FH R Revision Register 

6FH W IDE/PCMCIA Control Register 


NOTE: Register types are as follows: R/W = Read/Write; R = Read Only; W = Write Only. 
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3.3 Formatter Registers 


Address Type Description/Function 

4DH R Data Latch Register (for read accesses of the data buffer through Reg- 
isters 68H and 70H) 

4EH R/W Sector Size Register (for larger than 512-byte data fields) 

69H R Sector Status Register 

69H WwW Increment Sector Count Register 

6AH R/W Sector Target Register 

6BH R/AW Sector Count Register 

6CH R/W React Branch Register 

6DH RAW MSB Sector Remaining Counter 

6EH RW LSB Sector Remaining Counter 

71H R/W Control Register for ECC: Bit 5 — which can be set from the RST* Pin 


or the microcontroller — is the Formatter reset. When set, a constant 
reset will be asserted that stops all operations within the Formatter and 
drops RG, WG, WAM and NRZ Outputs. This reset also clears the in- 
terrupt enables. 


72H R ECC Syndrome Shift Register 

72H W Correction Done Reset 

74H RW ECC Offset Correction Count (MSB) 
75H RW ECC Offset Correction Count (LSB) 
76H R/W Synchronization Byte-Count Limit 
77H RW Formatter Mode Selection 

78H Ww Branch Address Register 

79H R Formatter Status Register 

79H WwW Sequencer Start Address Register 
7AH R/W Operation Control/Status Register 
7BH RW WAM Output Timing Control Register 
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3.3 Formatter Registers (cont.) 


Address Type Description/Functlon 

7CH RAW Address Mark Detect Control Register (to be compared with NRZ read 
ae The number of bits to be compared is controlled by Register 

7DH RAW Formatter Interrupt Status Register 

7EH RW Formatter Interrupt Enable Register 

7FH R Stack: When reading, contents of the top of stack are presented to the 


bus and the stack is rotated. 


7FH W Clock Control and Sync Compare Register 


3.4 Control Registers 


Address Type Description/Function 

48H R/W Auxiliary Control Register 0 for mode selection of Formatter and buffer 
options. 

4FH R/W Auxiliary Control Register 1 for mode selection of Formatter and local 


microcontroller interface options. 


3.5 Sequencer Registers 
Address Type Description/Function 


80H-9EH RAW Next Address Field of the WCS Word: This is the address that the Se- 
quencer will go to after the down-counter has reached zero, and a 
branch has not been taken. 


AOH-BEH R/W Control Field of the WCS Word 


COH-DEH RAW Count Field of the WCS Word: This sets the initial value of the Se- 
quencer counter when a new state is entered. 


EQH-FEH RAW Data Field of the WCS Word: This is the source for all overhead bytes 
of data used by the device during Write Operations. During Read Op- 
erations, it is one of the operands to the comparison logic. 


49H-4CH R/W This allows the microcontroller to access the Current Sequencer Word. 
There is no protection against access contention between the micro- 
controller and Sequencer. These registers are for test purposes 
only. 
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3.6 Register Initialization 
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3.6 Register Initialization (cont) 


Register. |HRSTYHRST| RST* |Host Prog.) REG 59H | REG59H | REG71H REGISTER BIT VALUE Notes 
Address (Pin 53/2) |(Pin 34/83)/ Reset | (Write) |(BitO=1)| (BRS5=1) | 7 6 5 4 3 210 
GO oh We les ace 


6FH (Read) 
6FH (Write) 
70H 
71H 
72H 
73H 
74H 
78H 
76H 
77H 
78H 
79H (Read) 
7AH 


oO 


— 


=lolojoslaololololol/o|x|olololo|xl/ol=a|xilxixio 
=lO/Ololol/ol/ololoj|xXx|lololololo|xlolo|x|x|lxio 
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=~lOlOlol/ol/olOojfolol/aolololol/ol/olxXlololx|x|xjo 
=H=fOlOlOl/Ol/Ol/Ol/OlAOlOlOjoO;/oOl/oOjo]xX/oOololx|x)]xio 


is : 


i 


O/OLOJO]KXSOlLOSOlOyKXIOTO|K|x«K |x 


: 


7EH 

7FH (Write) 
9FH 

BFH 

DFH 

FFH 
80H-9EH 
A0-BEH 
CO-DEH 
E0-FEH 


OLOSOLOLOLOJSO}]KIOC}SO]SOJO]KIO]LOIYxXIxK|]x}oO 


«| >< -f|o 
< |x | KX -1|o}°o 
x | MK LK EO 
«| «KL <1 OX 


x 
x 


~~ 
wo 
=x 


SN 
7 


Pa 
«|< | x | xX 
x | KL KL OX 
x) «KL | >< 
xy x< | «| >x< 


NOTES: 1) This table only lists reset conditions that are common to all bits in each register. For reset conditions 
of individual bits in these registers, see the detailed register descriptions in Section 5. 

2) Registers 5CH and 5DH are also reset by an auto-command. 

3) Registers 5EH and 5FH are also set to 01H and OFFH, respectively, by an auto-command. 


4) The state of Bit 0 will depend on how the BD5/IDE/PCMCIA Signal (Pin 98/47) is configured. 
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3.7 Register Memory Map 


SECTR REMAIN 
COUNTER 
FR 


HOST ADDR 


POINTER(HAP} 


Nex 
BRNCH 
REG 


DISK ADDR 
POINTER(DAP) 

COUNT 

REG 
OPER | WAM | AMD 
CNTRL | CNTRL | CNTRL 


CURRENT SEQUENCER 
WORD 
TARGT 
REG 


HOST CONTROL’ 


STATUS REGISTERS 
ie 
ese 


ALTERNATE ADDRESS FOR HOST 


REGISTER ADDRESS - LOWER NIBBLE 
7 


TASK FILE 
U 

SIZE 

REG 


ALTERNATE ADDRESS FOR HOST 
BU 
CNTRL 
REG 


t 
CNTRL! 
STAT 


C7 Optionally a 
Enabled 
ADDR. FIELD FIELD FIELD 
FIELD 
Writable Control Store (WCS) 
REGISTER ADDRESS — UPPER NIBBLE 
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4. FUNCTIONAL DESCRIPTION 


The CL-SH361 is designed to be used with a low- 
cost microcontroller that allows it to maintain a 
‘loose’ synchronization with the real-time disk op- 
eration. The CL-SH361 maintains ‘close’ synchro- 
nization with the data to and from the disk drive 
and provides the signals necessary to contro! this 
path. Using the CL-SH361 means a lower-total- 
part count for an intelligent disk drive design with 
the PC XT/AT interface. 


The CL-SH361 has four functional blocks: 


» Microcontroller Interface 

« Sector Formatter and Sequencer 
+ Buffer Manager Interface 

« PC XT/AT Interface 


4.1. Microcontroller Interface 

The microcontroller-to-CL-SH361 communication 
path is a multiplexed/non-multiplexed address and 
data bus similar to that provided by the Intel 8051- 
and the Motorola 68HC11-class of controllers. The 
CL-SH361 can use either the Intel or the Motorola 
method of data control. When the Intel interface is 
selected, the WR*/R/W* Signal (Pin 7/56) acts as 
a write strobe. In the case of a Write Operation, 
this write strobe provides the timing and contro! for 
the data transfers. Similarly, in the case of a Read 
Operation, the RD*/DS Signal (Pin 8/57) acts as a 
read strobe to provide the timing and control for the 
data transfers. 


Table 4-1. Buffer Data Bus Option Settings 


rt 
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The BD6/I/MC* Signal (Pin 99/48) defaults to Intel 
Mode after reset, with no external resistor. An 
external pull-down resistor is required to operate in 
the Motorola Interface Mode. For the Motorola 
configuration, the WR*/R/W” Signal (Pin 7/56) is 
used only to determine the direction of the data 
transfer. When the input to this signal is high, a 
Read Operation is in progress; when it is low, a 
Write Operation is in progress. Data timing is 
derived with respect to the RD*/DS Signal (Pin 8/ 
57). In the case of a Read Operation, the rising 
(leading) edge of the RD*/DS Signal (Pin 8/57) 
indicates when the CL-SH361 can start driving the 
data bus. In a Write Operation, the falling (trailing) 
edge is used by the CL-SH361 to latch the data 
from the microcontroller address/data bus. 


The CL-SH361 uses the BD7/M/NM* Signal (Pin 
100/49) after a reset to select a multiplexed or a 
non-multiplexed address and data path. The 
BD7/M/NM* Signal (Pin 100/49) has an internal 
pull-down. If this pin is connected to a pull-up re- 
sistor after reset, the CL-SH361 will recognize this 
condition and will automatically select Multiplexed 
Mode. Following reset, if the BD7/M/NM* Signal 
(Pin 100/49) is only connected to ihe Data Port of 
the buffer RAM without an external pull-up resistor, 
the CL-SH361 will recognize the low level (internal 
pull-down) on this signal and select Non-multi- 
plexed Mode. 


Table 4—1 provides the buffer data bus switch op- 
tion settings in a tabular format. 


Mode with Resistor Presents 
Multiplexed Mode 


Motorola Mode 


PCMCIA-compatible Mode 
User-defined 


User-defined 


Signal Type of External Resistor 
BD7/M/NM* Pull-up 

BD6/l/MC* Pull-down 
BD5/IDE/PCMCIA* Pull-down 

BD4 Optional ‘Switch’ 
BD3 Optional ‘Switch’ 
BD2 Optional ‘Switch’ 
BD1 Optional ‘Switch’ 
BDO Optional ‘Switch’ 


NOTE: BD4 through BDO are general-purpose switches. 
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The CL-SH361 decodes addresses from 40H to 
FFH. To prevent erroneous operations, the 
controller design should reserve the decoding of 
Addresses 40H to FFH for the controller chip only. 
The PC Interface Register File is mapped to 40H- 
47H or 60H-67H. Upon a local reset (RST* — Pin 
34/83), the access to the PC Register File is 
disabled until the Register File base address is 
programmed by the local microcontroller; this 
avoids contention on the read cycle, or errors on 
the write cycle. 


The CL-SH361 has a programmable interrupt cir- 
cuit. Four interrupt Registers provide the status 
and mask programmability for interrupt sources. 
The programmable interrupt features include indi- 
vidual masks, a global enable, and an open-drain 
or push-pull output driver. The interrupt status reg- 
isters may also be used as a focal point for micro- 
controller control when the CL-SH361 is being 
used in a Polied Mode. The interrupt sources are: 
PC Selection, PC Transfer Done, PC Reset, PC 
Transfer Overrun, Host Transfer Status Read De- 
tected, Index Past, Sector Past, Disk Data Trans- 
fer Detected, ECC/Uncorrectable Error, Sequenc- 
er Stopped, Input Detected, and Sequencer 
Output Detected. 


The processor-readable switches are multiplexed 
with the buffer data bus. These switches must be 
installed with relatively high-impedance pull-ups 
and pull-downs so that the resistor impedance 
does not affect the buffer performance. The 
processor accesses these switches by reading 
Registers 68H or 70H, with the MOE* Disable Bit 
set (Register 52H, Bit 0). 


Switch Example 


Buffer Data Bus Bit 
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4.1.1 Access to External Buses 


In addition to the normal data transfer operations, 
the CL-SH361 also supports microcontroller ac- 
cess to the buffer memory by addressing Regis- 
ters 68H and 70H. 


4.1.1.1 Microcontroller Scheduled Access to 


A Register-68H decode is provided for the proces- 
sor to gain scheduled access to the buffer. The ad- 
dress is generated based upon the contents of the 
Disk Address Pointer. The Disk Address Pointer 
will be incremented by a Register 68H access if the 
Buffer Pointer Auto-Increment Bit is set (Register 
48H, Bit 0). The buffer read or write is scheduled 
by the Buffer Manager. This allows concurrent PC- 
and-local-microcontroller access to the buffer 
memory. 


The processor-readable switches are also 
accessible by a Register-68H read. These 
switches must be installed as earlier described. 
(High-impedance pullups and pull-downs are 
recommended so buffer performance is not 
affected.) 


4.1.1.2 Microcontrolier Unscheduled Access 
to Buffer 


A Register-70H decode is provided for the proces- 
sor to gain access to the buffer when there is no 
PC disk transfer or ECC correction in progress. 
The processor-readable switches are also access- 
ed by a Register 70H Read. 


4.1.2 Power-Down Mode 


The CL-SH361 can support three levels of firm- 
ware controlled Power-Down Operation. The level 
of power-down is selected by mode bits in Register 
4FH. The appropriate mode is selected by the lo- 
cal microcontroller. The three levels of power- 
down in the CL-SH361 are summarized in the fol- 
lowing table: 


Register Mode 
Logic 0: Switch Closed one 4FH, Bit 5 Local Interface 
Logic 1: Switch Open 4FH, Bit 6 Host ATA Power-Down 
y 4FH, Bit 7 Host Deep Sleep Mode 
2 —=——=—=_=_——_==—_$=_—_—— NM yy 19:92 
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The most power-saving level for the host interface 
is Host Deep Sleep Mode. !n this mode, only the 
assertion of HRST*/HRST (Pin 53/2) or RST* (Pin 
34/83) will activate the CL-SH361. It is estimated 
that power dissipation in this mode will be less than 
3 mW. 


The next level of power-down is the Host ATA 
Mode. The CL-SH361 will exit this mode only 
when the host issues a soft reset by setting the 
RESET Bit (Bit 2) in the AT Fixed Disk Register 
(Host Register 3F6), the assertion of HRST*/ 
HRST (Pin 53/2), or RST* (Pin 34/83). 


The third level is the local interface. The CL- 
SH361 will recognize a write to the AT Command 
Register or the XT Controller Select Register, as- 
sertion of HRST*/HRST (Pin 53/2), RST* (Pin 34/ 
83) or setting the Reset Bit in the AT Fixed Disk 
Register (Bit 2) and exiting this mode. When this 
mode is exited, the Assertion Bit (Register 4FH, Bit 
5) will be ‘locked’ until the microcontroller has per- 
formed the ‘unlock’ write to Register 73H. 


4.2. Sector Formatter and Sequencer 


The basic operation of the Sector Formatter is con- 
trolled by the contents of the Sequencer Writable 
Control Store (WCS). A Sequencer program must 
be entered into the WCS before the CL-SH361 
Sector Formatter can function properly. Under 
firmware control, the Sector Formatter can be 
made to sequence through different types of oper- 
ations, such as: ‘Read ID’, ‘Read ID and Read 
Data’, ‘Read ID and Write Data’, and ‘Write 1D and 
Write Data’. 


The Sequencer controls the timing relationships 
between the disk-interface output signals and 
monitors the disk-interface input lines to branch to 
different Sequencer locations. The track layout, 
such as gap lengths, sector size, and sector data 
fill character, can be flexibly defined in the WCS. 
The CL-SH361 Sector Formatter also has other 
registers that can be used to control the definition 
of the track format such as the SYNC character 
and the Address Mark. 


The WCS consists of 124 bytes, organized as 31 
words, each four bytes wide. The WCS can be 
broken down into Data/Branch, Count, Control, 
and Next Address Fields. 


May 1992 


== 


=== CIRRUS LOGIC 


The Data/Branch Field contains data that may be 
used to initialize the track format, including gap, ID 
field, and sector-data-fill characters. This data can 
also be compared to the NRZ data-in to identify 
various fields in a sector or to execute sector data 
comparisons. The contents of this field may also 
be used as a branch address to tell the Sequencer 
which address to jump to upon the evaluation of a 
branch condition. 


The Count Field specifies the initial value, minus 
one of the Sequencer counter for the current word. 
The Sequencer counter is decremented once ev- 
ery eight Read/Reference Clock (RD/REF CLK) 
cycles. When the count reaches zero, the Se- 
quencer will go to the next address. 


The next address will be based on the contents of 
the Next Address Field of the WCS word, unless a 
branch condition has been programmed and met 
during the last byte of the current WCS word. 


The Control Field is used to generate and initiate 
all synchronous NRZ-data-handling operations. 


The microcontrollers manipulation of the Sequenc- 
er revolves around the: Start/Status Register 
(Register 79H), Branch Register (Register 78H), 
WCS Data/Branch and the React Branch Register 
(Register 6CH). Writing to Register 79H loads the 
starting address where the Sequencer is to begin 
execution, and causes the four bytes at that WCS 
RAM word to be fetched and written into the Cur- 
rent Sequencer Word Registers. The next address 
to be fetched is based upon the contents of the 
Next Address Field in the Sequencer Registers, 
unless a specified branch condition is met. If the 
branch condition specified in the Next Address 
Field is met, the next address to be executed is 
based upon the contents of the Branch Address 
Register, Register 78H, the React Branch Regis- 
ter, Register 6CH, or the WCS Data Field. Thus, 
by setting up different branch conditions that are 
based on external or internal events, the chip can 
be made to sequence through different operations. 


The serial data flow portion of the Sector Formatter 
consists of a 16-bit CRC, 88-bit ECC and a 
serializer/deserializer. Data to be written to the 
disk enters the CL-SH361 from the host in either a 
word, or a byte-wide format. It is serialized and 
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processed through a 16-bit CRC, 88-bit ECC 
generator. An NRZ serial bit stream is then shifted 
out to the drive. Note that the NRZ- serial-bit 
stream will include serialized constants required 
for address marks, gaps, and ID fields, as well as 
the serialized data and ECC-generated output. 


The ECC can be programmed (in the WCS) for 16- 
bit CRC-CCITT for the ID field and an 88-bit Reed- 
Solomon polynomial for the data field. The 16-bit 
CRC-CCITT code can only be used for error 
detection. If an ECC error is detected after a Read 
Data Operation, the syndrome is saved in the 
internal correction registers and the ECC Error Bit 
(Register 79H, Bit 2) is set. The CL-SH361 has 
advanced correction logic that can determine the 
following: if the error is correctable, calculate the 
error pattern and its displacement from the 
beginning of the Data Field, and correct the error 
in the Buffer RAM. If the Hardware Correction 
Enable Bit (Register 71H, Bit 0) is set, hardware 
correction is performed while the next sector is 
being read. If the error is correctable, the hardware 
corrects the data and sets the Correction Done Bit 
(Register 79H, Bit 4). If the error is uncorrectable, 
the ECC Error and Uncorrectable ECC Error Bits 
(Register 79H, Bits 2 and 3) are set to prompt the 
local microcontroller to take appropriate actions. If 
the Hardware Correction Enable Bit is reset, the 
ECC Error and Uncorrectable ECC Error Status 
Bits are set after the Read Data Operation, and the 
syndrome is transferred to the internal correction 
register. It is readable by the local microcontroller 
through Register 72H, and can be read in 8-bit 
increments for firmware-assisted correction. 


The following is the 16-bit CRC-CCITT polynomial: 
yO yl Sa 


The 88-bit ECC Reed-Solomon code is a non-in- 
terleaved code of degree 8, operating on 10-bit 
symbols. The code is capable of correcting four 
10-bit symbols that are in error. This gives the 
code the guaranteed ability to correct one 31-bit 
burst or two 11-bit bursts. 


The on-the-fly hardware correction is set at 11 bits. 
This gives an on-the-fly detection capability of a 
51-bit burst or three 11-bit bursts. It is 
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recommended that software correction after retry 
be limited to a single 22-bit burst or two 11-bit 
bursts. 


The probability of miscorrection for the on-the-fly 
circuitry is: 


z nx 221-1 
me 
.m 


where, 

n= sector length in bits, including redundancy bits 
61 = correction span in bits 

m = total number of redundancy bits. 


This provides the automatic on-the-fly hardware a 
miscorrection probability of approximately 10°20 
per bit corrected for a 512-byte field (with a single- 
byte address mark). 


The probability of miscorrection for the software 
correction algorithm is: 


2 

1 nx28?-1 nx (n— 63) x (22-4) 

Paik a * i 
qin am 2m 


where, 


n= sector length in bits, including redundancy bits 
b2 = single-burst correction span in bits 

b3 = double-burst correction span in bits 

m= total number of redundancy bits. 


The CL-SH361 Sector Formatter also has a recir- 
culating stack that is eight bytes deep. By enabling 
the stack (setting Bit 4 of the WCS Control Field) 
during a read process, information read from the 
drive can be pushed onto the stack to be examined 
later at a lower speed by the microcontroller. This 
capability can be used to pass the ID field to the 
microcontroller for defect management, seek veri- 
fication and other disk controller tasks. 


4.2.1. Extended-Data-Handling Operations 


The CL-SH361 has the ability to flexibly handle a 
large variety of different sector configurations. The 
next four subsections discuss various sector sizes, 
split data fields, multiple-sector Read/Write 
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Operations with minimal microcontroller 
intervention, and scheduled access to the WCS by 
the local microcontroller. 


4.2.1.1 Variable Sector Size 


The CL-SH361 Sector Formatter has an 8-bit data 
field length counter loadable from the Count Field 
of the Sequencer RAM. This field is programma- 
ble, and by setting this field to any value from 00H 
to FFH, asector length up to 256 bytes can be writ- 
ten to the drive. The value of this counter is always 
one less than the actual sector length. For sector 
sizes greater than 256 bytes, several different 
methods can be used. 


The simplest approach is to use as many Se- 
quencer words as required to implement the count 
for the data field. 


The next approach uses the Inhibit Carry Bit in the 
Operation Control Register (Register 7AH, Bit 7). 
By setting the Inhibit Carry Bit and programming 
the Next Address Field of the Formatter WCS with 
the most significant bits set to 100 during data 
transfer, the CL-SH361 Sector Formatter will be in- 
hibited from going to the Next Sequencer Word; 
another 256 bytes of data will be transferred. The 
256-byte count number is programmed in the Sec- 
tor Size Register (Register 4EH). 


A value of zero (from a chip reset) will provide one 
suppression as described above, (i.e., for 532 
bytes, start with the sector size set to one, and an 
initial count of 19). 


4.2.1.2 Split Data Field Operation 


For high-density drives, it is desirable to have 
more embedded servo fields on a track to keep the 
head centered above the track. The Split Data 
Field Operation allows the data field of a sector to 
be split into multiple sections so that servo fields 
can be inserted. Split Data Field can also be used 
for flaw management. The programmability of the 
CL-SH361 Sequencer RAM provides flexible han- 
dling of split data fields. 


There are two methods of handling data splits in 


the WCS. By resetting the Advance Multisector/ 
Multisector* Control Bit (Register 4FH, Bit 0), the 
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Sequencer will use Bit 3 of the WCS Control Field 
as the Process Soplit/Fiag Bit to control the split 
boundaries. Using this bit allows the transfer of 
data in full blocks or in split format from buffer to 
disk or disk to buffer. This method requires the mi- 
crocontroller to update the WCS for every sector 
Read/Write Operation for proper data split han- 
dling. 


The byte count of the split data field is specified by 
the count field of the Sequencer RAM. The servo- 
field sizes of split data fields are also specified by 
the Sequencer RAM Count Field. 


The operation of freezing the ECC generation dur- 
ing a Write Operation or checking for a Split Data 
Field during a Read Operation is called Split/ 
Freeze ECC. Restarting the ECC circuitry for the 
remainder of the split data is called Restart ECC/ 
Continue Data Split. 


To perform a Split/Freeze ECC Operation, the 
Process Split Bit of the WCS Data Control Field 
should be set in the last Data Transfer Sequencer 
Word. The CL-SH361 will recognize this operation; 
at the end of the data transfer count, it freezes the 
ECC generator and when the Data Transfer Bit of 
the Sequencer Control Field is set for the next split, 
it unfreezes the ECC generator and continues the 
transfer of data to/from the buffer. To further split 
the data, repeat the operation by setting the 
Process Split/Flag Bit of the WCS Data Control 
Field on the last Data Transfer Sequencer Word. 


The second method is the Advanced Multisector 
Read/Write Operation where the splits are embed- 
ded in the ID field; by setting the proper flags, the 
split counts are processed by the Sequencer with- 
out the microcontroller having to ir ‘ervene. 


4.2.1.3 Multisector Read/Write Operation 


The CL-SH361 supports Multisector Read or Write 
Operations with minimal microcontroller interven- 
tion. This can be accomplished by two methods. 
The simplest method is to ioad the next sector ID 
to be accessed while data transfer is active (Reg- 
ister 79H, Bit 7) for the present sector, and restart- 
ing the Read or Write Operation immediately after 
the end of the present sector. 
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The second approach uses the Sector Target ID 
Register and Sector Count Register to transfer 
multiple sectors to/from the buffer under WCS con- 
trol. This method is selected by setting the Ad- 
vanced Multisector/Multisector* Control Bit (Regis- 
ter 4FH, Bit 0). The CL-SH361 will use a number 
of internal registers to support advanced multisec- 
tor transfers. These are: the Sector Remaining 
Register, the Sector Target Register and the Sec- 
tor Count Register. The Sector Remaining Regis- 
ter controls the number of bytes per sector. This 
register is loaded by the microcontroller with the 
length, in bytes, of the data field. The Sector Tar- 
get Register is loaded by the microcontroller with 
the starting sector number and the Sector Count 
Register is loaded with the number of sectors to be 
processed. Therefore, by proper programming of 
the WCS and the start address in the Sector Tar- 
get Register and the number of sectors to be pro- 
cessed in the Sector Count Register, the Sequenc- 
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er can perform Multisector Read/Write Operations 
with minimum real-time intervention by the micro- 
controller. 


This method supports Constant Density Recording 
formats with variable data splits, and an 
alternate-/skipped-defective-sector scheme with 
minimal-latency sector operations. The data split 
counts for each sector are embedded in their ID 
field. Therefore, this allows the Sequencer to save 
these counts via an internal FIFO during the read 
of an ID and then use these values for proper han- 
dling of the data field with no intervention from the 
microcontroller. The split counts will be 12 bits in 
length for a maximum data split field length of 4K 
bytes. In addition, there are three flag bits for de- 
fect management and split-count designation. An 
example of the ID is illustrated in Figure 4—1 on the 
following page. 
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PLO ADDRESS} CYL | CYL SECTOR | Fla ; 
238s MARK | HIGH | Low} 4A?) NuMBER MS Split L Split | CRC 


7 6 


7:0 


5 4 3:0 
Push | End of MS Split ; 


Flag/MS Split Count 


Bit 7 PUSH FIFO: For Read and Write Operations, if this bit is set when the Advanced Mul- 
tisector/Multisector* Control Bit (Register 4FH, Bit 0) is set, the Read Gate is asserted, 
and the Process Split/Flag Bit of the WCS Control Field is set, it pushes the contents 
of the Read ID Field Flag/MS Split Count value and the following byte LS Split Count 
value into the internal FIFO; these values are used for the actual split count of the 
data-field-format operations in the internal FIFO. If this bit is set when Write Gate is 
asserted and the Process Split/Flag Bit of the WCS Control Field is set, it pushes the 
content of the WCS Data Field Register into the internal FIFO where these values are 
used for the actual Split Count of the data field. Therefore, the firmware engineer only 
changes the WCS Data Fieid for the proper format of the actual sector. This saves 
time during format operation. 


Bit 6 END OF TRACK: When this bit is set, if there was a good compare and good CRC 
and the Sector Count Register is not equal to zero, the Sector Target is reset to OOH at 
the end of the data transfer; the next sector to be read is Sector OOH. This function is 
used for Minimal Latency Operation, not Start/Stop Operation (explained in Section 


4.2.1.3.1). 
Bit 5 Not used. 
Bit 4 DEFECT: This bit is used to indicate a defective sector. It is used for the Alternate Sec- 


tor Scheme only where the defective sector is relocated to another location on the 
disk. This bit will determine the type of action to be taken using the proper WCS 
branch conditions. 


Bits 3:0 These are the upper four bits of the split count for the data field. 


LS Split Count 


Bits 7:0 These are the lower eight bits of the split count for the data field. 


Figure 4—1. Sample ID Field for Multisector Operation 


NOTE: This refers to Section 4.2.1.3, Multisector Read/Write Operation. 
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4.2.1.3.1 Minimum-Latency Multisector 
Transfer 


For minimum-iatency operations, the Sector Count 
Register (6BH) should be loaded with the maxi- 
mum number of sectors/track. The firmware reads 
the first ID field after the head reaches the track; it 
Starts the Sequencer and only checks for good 
CRC and no defect, and pushes it into the stack. 
By reading the stack, it can appropriately load the 
Sector Target (6AH) with the next sector value and 
program the Disk Pointer (Register 5AH, 5BH) with 
the correct location of this sector in the buffer. The 
CL-SH361 will proceed to read/write the full track. 
At the end of the track, if the Sector Count Register 
is not equal to zero and the End of Track Bit in the 
ID Flag/LS Split Count Byte is set, the Sector Tar- 
get Count Register (6AH) is appropriately reset to 
zero. The wrap of the Buffer Disk Pointer is con- 
trolled by setting the Buffer Start and Buffer End 
Address Pointers to values corresponding to the 
size of the track. Therefore, when the Disk Ad- 
dress Pointer (DAP) reaches the Buffer End Ad- 
dress, the DAP will be loaded with the Buffer Start 
Address. The next sector to be processed is Sec- 
tor ‘OOH’. This will save a maximum of one revolu- 
tion before the right sector is reached. 


4.2.1.3.2 Start/Stop Multisector Transfer 


In a Start/Stop Multisector Operation, the Sector 
Count Register (6BH) is loaded with the number of 
sectors to be read or written, and the Sector Target 
Register (6AH) is loaded with the starting sector 
value. The Sequencer will start and stop 
appropriately at the end of the transfer of the last 
sector. There are multiple branch conditions that 
may stop the Sequencer before ail the sectors are 
transferred. For example, if the previous sector 
ECC error is uncorrectable, the Sequencer will be 
stopped; if the Defect Bit in the Flag/LS Split Count 
Byte of the ID field is set, the Sequencer may stop 
or may take an alternate route in the WCS Map by 
the means of the React Branch Register (6CH). 


4.2.1.4 Scheduled WCS Access 


The WCS can be accessed by the microcontroller 
in a scheduled format. The Mode Bit — Scheduled 
WCS Access/Enable Bit (Register 7AH, Bit 6) — 
indicates the type of WCS access. If the 
Scheduled WCS Access/Enable Bit (Register 


2 
° DATA SHEET 


CL-SH361 
PC XT/AT Disk Controller 


7AH, Bit 6) is set, the access to/from the WCS is 
scheduled through the Status WCS Byte Ready Bit 
(Register 7AH, Bit 4). When reading the WCS, the 
address is latched internally; the data is 
synchronously read from the WCS to an internal 
hoiding register, and the WCS Byte Ready Bit 
(Register 7AH, Bit 4) is set. After this bit is set, the 
microcontroller may read the next location or the 
same location again; the data read is the previous 
address data information and the process repeats. 
When writing to the WCS, the address and data is 
latched internally, and the data is synchronously 
written to the WCS. The WCS Byte Ready Bit 
(Register 7AH, Bit 4) is set to indicate that it is 
ready to accept another WCS Write Operation. 


4.2.2 Functional Operation 


The CL-SH361 performs two basic disk opera- 
tions, reading NRZ data in and writing NRZ data 
out. These two operations can be combined easily 
into the following three major functions: Verify Sec- 
tor, Format Sector and Disk Data Transfer. The 
CL-SH361 also performs data transfers to/from the 
PC. These can be broken down into two major 
groups: Data Transfer by PIO, and Data Transfer 
by DMA. These two host transfer options will be 
discussed in Section 4.4, PC XT/AT interface. 


4.2.2.1 Verify Sector 


By setting the Suppress Transfer Bit in the Opera- 
tion Control Register, (Register 7AH, Bit 5) and 
performing a Read Operation, the read data will 
only be verified for good ECC and will not be trans- 
ferred to the buffer. 


4.2.2.2 Format Sector 


To format a track, the ID fields, all gaps (fill, 
postambles, and preambles), and data fields must 
be generated. This requires that the read ID field 
subroutine must be changed into a Write 
Operation, and appropriate gaps inserted. Also, by 
setting the Suppress Transfer Bit in the Operation 
Control Register (Register 7AH, Bit 5), the data for 
the Sector Data Field will be sourced from the 
Current Sequencer Word Data Field and will not be 
transferred from the buffer. The ID field bytes can 
be written from the buffer instead of updated by the 
local microcontroller. This is accomplished by 
setting the Data Transfer Bit in the WCS Control 
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Field. This will override the suppress-transfer 
function for the 1D field only. If this method is used 
the local microcontroller must ‘unlock’ the buffer 
after the format command is received so that the 
ID field values can be retrieved. 


4.2.2.3 Disk Data Transfer 


For disk transfers, a byte is transferred each time 
the Formatter requires a data transfer (to serialize/ 
deserialize a byte). The direction of transfer is 
determined by the Buffer/Disk R/W* Transfer 
Direction Bit (Register 53H, Bit 4). The Disk 
Address Pointer is used to select the buffer 
memory location. 


For a Disk Read Operation, where disk NRZ data 
is deserialized and written to the buffer, the Buffer/ 
Disk R/W" Transfer Direction Bit (Register 53H, Bit 
4) must be set. When the disk transfer stops, the 
Disk Data Transfer Bit (Register 79H, Bit 7) is re- 
set. 


For a Disk Write Operation, where buffer data is 
serialized and written out to the disk as NRZ data, 
the Disk/Buffer R/W* Transfer Direction Bit (Regis- 
ter 53H, Bit 4) is reset. When the disk transfer 
stops, the Disk Data Transfer Bit (Register 79H, Bit 
7) is reset. 


4.2.3. Two Index Counter 


Another component of the Format Sequencer is 
the Two Index Counter (TIC). This circuit is used to 
limit the execution of a Format Sequencer program 
to one complete revolution of the disk drive. This 
feature would typically be used to limit the number 
of the times that the Format Sequencer would at- 
tempt to search for the Sector !D Field of a Target 
Sector. 


When the Two Index Detection Mode Enable Bit 
(Register 48H, Bit 6) is set, the Two Index Detec- 
tion Mode circuitry is armed or rearmed by the 
WCS. The detection circuit is armed if the WCS 
Control Field has both Read Gate and Data Trans- 
fer off, and Bit 5 of the Count Field is set. Once the 
circuit is armed, it remains armed until one of fol- 
lowing three events happens: 1) data transfer oc- 
curs between the Formatter and buffer; 2) Two In- 
dex pulses are detected and the Formatter is 
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stopped; or 3) the Two Index Detection Mode En- 
able Bit is reset. When the detection circuit is 
armed, and the Two Index edges are detected, the 
Two Index Detected Status Bit is set (Register 
48H, Bit 3). The status bit remains set until the Two 
Index Detection Mode is disabled (Register 48, Bit 
6). When the Two Index Detected Status Bit is set, 
it asserts the ‘stopped’ signal to stop the Formatter 
Operation; this disarms the detection circuit. 


4.2.4 Synchronization Timer 


The Synchronization Timer is a circuit used to set 
a limit on the amount of time that the Format Se- 
quencer is allotted to synchronize itself — or find 
and match the synchronization byte pattern de- 
fined in Register 7CH — with the incoming NRZ 
data stream. This limit is programmed in the 
CL-SH361 Synchronization Byte Count Limit Reg- 
ister (76H). This limit is specified in terms of a byte- 
count limit that can range from 0 to 255. Only one 
value can be programmed into Register 76H. 
When the Synchronization Timer is activated by 
the Format Sequencer program, the value in Reg- 
ister 76H is decremented for each byte time that 
passes. When the value within Register 76H 
reaches zero, a time-out occurs. When a time-out 
error occurs, the Format Sequencer can stop or 
branch (see Next Address Field Register descrip- 
tion). In either case, the Synchronization Time-Out 
Error Bit (Register 48H, Bit 2) will also be set. The 
branch source is the WCS Data Field. This bit is re- 
set by a Formatter reset (Register 71H, Bit 5) and 
a Sequencer start. 


The Format Sequencer program can activate the 
Synchronization Timer by setting the Count/Start 
Synchronization Timer/Two Index Timer Bit (Bit 5 
of the Writable Control Store (WCS) Count Field). 
This mode is selected when the Read Gate On (Bit 
5-6 of the WCS Control Field Register) is set. Once 
the timer is activated, the time-out will either stop 
the Sequencer or branch to a new address. To set- 
up the branch condition, the WCS Data Field is set 
to the branch address during Read Gate On. The 
Synchronization Timer is reset under the following 
conditions: (1) when the Format Sequencer is re- 
set, or (2) when the serial synchronization detector 
finds the synchronization character (as defined in 
Register 7CH) in the incoming NRZ data stream. 
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This feature would typically be used to limit the 
amount of time that the Format Sequencer is al- 
lowed to search for the Sector Data Field after it 
successfully completes a Sector-ID-Field compar- 
ison. The Synchronization Timer can also be used 
to limit the amount of time that the Format Se- 
quencer searches for a Sector ID Field after a sec- 
tor mark is detected in a hard-sectored disk drive. 


4.3. Buffer Manager Interface 


The third functional logic block of the CL-SH361 is 
the Buffer Manager interface. This block controls 
the flow of data between the external RAM data 
buffer and the CL-SH361 PC interface, the Sector 
Formatter data path, and the microcontroller buffer 
memory access ports. The Buffer Manager inter- 
face provides the external RAM addressing, tim- 
ing, and control signals necessary for the CL- 
$H361 to interface with the RAM data buffer. 


4.3.1. SRAM Addressing Operation 


The Buffer Manager interface can address up to 
64K bytes of static memory. This requires 16 ad- 
dress lines that correspond to the Buffer Manager 
Address Signals BA[15:0] (PQFP Pins 90-79 and 
77-74; VQFP Pins 39-28 and 26-23). The buffer 
memory address is never placed in a high-imped- 
ance state; it is always driven by one of three 
sources — the Disk Address Pointer (Registers 
5AH-5BH), the Host Address Pointer (Registers 
5CH-5DH) or the ECC Corrector. These pointers 
have various initialization conditions, and their 
starting values can be changed via direct firmware 
control. 


The Disk Address Pointer (Registers 5AH-5Bh) is 
dedicated for disk and microcontroller transfers. 
Any access to the RAM data buffer by the Sector 
Formatter selects the value in Registers 5AH-5BH, 
(the Disk Address Pointer) that will be driven out 
on the buffer memory address bus. 


When the local microcontroller accesses the buffer 
memory, the Disk Address Pointer (Registers 
5AH-5BH) is also used. Consequently, to prepare 
for a local microcontroller access to the buffer 
memory, all disk transfers to or from the CL-SH361 
must be terminated before the Disk Address Point- 
er (Registers 5AH-5Bh) is loaded. 
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The Host Address Pointer (Registers 5CH-5DH) is 
reserved for transfers between the PC bus and the 
RAM data buffer. Any access to the RAM data 
buffer by the PC interface logic selects the value in 
Registers 5CH-5DH, the Host Address Pointer, 
and has the CL-SH361 drive this value onto the 
buffer memory address bus. 


The Host Address Pointer (Registers 5CH-5DH) is 
compared with the Stop Address Pointer 
(Registers 5EH-5FH) to contain the data transfers 
to a particular block-boundary value. To translate 
the value of the Host Address Pointer (Registers 
5CH-5DH) into a repeatable block size, the Buffer 
Size/Segment Address Register (54H) is used to 
mask the upper address bits of the Host Address 
Pointer (Registers 5CH-5DH) and the Stop 
Address Pointer (Registers 5EH-5FH). 
Consequently, only the lower significant bits that 
are ‘modulo a’ block size are used for the 
comparison. When there is an equal comparison 
of the Host Address Pointer (Registers 5CH-5DH) 
and the Stop Address Pointer (Register 5DH- 
5FH), masked by the Buffer Size/Segment 
Address Register (54H), then the host transfer is 
terminated. 


Both the Disk Address Pointer (Registers 5AH- 
5BH) and the Host Address Pointer (Registers 
5CH-5DH) are automatically incremented by a 
count of one after the completion of each access 
to the RAM data buffer. 


4.3.2 Buffer Segmentation 


For optimum data flow control, it is often desirable 
to divide the buffer memory into smaller segments. 
The CL-SH361 Buffer Manager can support fixed 
and variable segment sizes. In Fixed Mode, the 
buffer can be divided into 4K, 8K, 16K, 32K or 64K 
segments. For example, with an attached buffer 
size of 32K and segment sizes of 4K, this would 
create eight 4K segments: 0000-OFFFH, 1000- 
1FFFH, 2000-2FFFH, 3000-3FFFH, 4000-4FFFH, 
5000-5FFFH, 6000-6FFFH, 7000-7FFFH. When 
operating in this mode, the Buffer Start Address 
Registers (9FH/BFH) and the Buffer End Address 
Registers (DFH/FFH) are loaded with the physical 
size of the attached static RAM buffer. Each seg- 
ment can be accessed by setting the upper four 
bits of the HAP and DAP to the desired segment 
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address. In this configuration, once the address 
pointer (HAP or DAP) reaches X1FFFH, the next 
address will roll over to X1000H. 


In the second mode, the CL-SH361 provides the 
ability to generate a variable segment within the 
buffer memory by providing Buffer Start Address 
Registers (9FH/BFH) and Buffer End Address 
Registers (DFH/FFH). By loading the Buffer Start 
Address Register (5EH-5FH) with the starting seg- 
ment address and the Buffer End Address Regis- 
ter (GEH-5FH) with the ending segment address, 
whenever the Disk Address Pointer (DAP — Reg- 
isters 5AH-5BH) or Host Address Pointer (HAP — 
Registers 5CH-5DH) are equal to the Buffer End 
Address Register, they are reloaded with the Buff- 
er Start Address Register value. When operating 
in this mode, the Buffer Size/Segment Address 
Register (Register 54H) must be set to the physi- 
cal size of the attached static RAM buffer. 


4.3.3. SRAM Read/Write Access Control 


The Buffer Manager accesses the buffer memory 
data bus to read or to write the contents of the 
RAM data buffer, or to read the static state of the 
data bus. The PC host, the Sector Formatter, and 
the local microcontroller all use unique methods to 
specify the direction of the access. 


For PC host transfers, the read/write control is set 
by the PC R/W* Transfer Direction Bit (Bit 3) of the 
Buffer Transfer Control Register (53H). When this 
bit is set, the data read from the RAM data buffer 
is transferred through the CL-SH361 chip to the 
PC host interface. If this bit is reset, then the data 
is transferred from the PC host interface through 
the CL-SH361 and written to the RAM data buffer. 


In the case of Sector Formatter transfers, the 
transfer direction is controlled by the Buffer/Disk 
R/MW* Transfer Direction Bit (Bit 4) of the Buffer 
Transfer Control Register (53H). When this bit is 
reset, the data read from the RAM data buffer is 
transferred to the Sector Formatter. To write to the 
RAM data buffer from the Sector Formatter, this bit 
must be set. 


For microcontroller transfers, the microcontroller 


contro! strobe is used to determine the transfer di- 
rection. A read of Register 68H (the Scheduled 
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Buffer Data Register) or Register 70H (the Micro- 
controller Buffer Access Register) results in a read 
of the RAM data buffer. A write to Register 68H 
(the Scheduled Buffer Data Register) or Register 
70H (the Microcontroller Buffer Access Register) 
causes a write to the RAM data buffer. 


Both a Read and Write Operation commence 
when the correct address pointer — the Disk Ad- 
dress Pointer (Registers 5AH-5BH), or the Host 
Address Pointer (Registers 5CH-5DH) — is driven 
onto the buffer memory address bus. 


For aread to the RAM data buffer, the Chip Enable 
Signal (CE1* — Pin 3/52) is asserted at the same 
time as the address is driven onto the address bus. 
The Memory Output Enable Signal (MOE* — Pin 
1/50) is asserted after the address is driven onto 
the address bus. This signal should be connected 
to the SRAM Output Enable(s) to ensure the high- 
est throughput. Data must be provided from the 
SRAM shortly before the rising (trailing) edge of 
the Memory Output Enable Signal (MOE* — Pin 1/ 
50). The Write Enable Signal (WE* — Pin 2/51) re- 
mains deasserted throughout the entire SRAM 
read access. 


For awrite to the RAM data buffer, the Chip Enable 
Signal (CE1* — Pin 3/52) is asserted at the same 
time as the address is driven onto the address bus; 
the Write Enable Signal (WE* — Pin 2/51) is 
asserted after the address is driven onto the 
address bus. The Memory Output Enable Signal 
(MOE* — Pin 1/50) remains deasserted (high) 
throughout the entire SRAM access. Data is driven 
from the CL-SH361 to the RAM data buffer shortly 
after the address. The Write Enable Signal (WE* 
— Pin 2/51) is deasserted (high) near the end of 
the cycle. The CL-SH361 supports two-chip 
enables for 64K buffers. This mode is controlled by 
Register 53H, Bit 0, and uses BA15/CE2* (Pin 90/ 
39) as the second chip enable. 


4.3.4 SRAM Signal Timing 


For both a read and a write access to the RAM 
data buffer, the correct address pointer (the Disk 
Address Pointer — Registers 5AH-5BH and the 
Host Address Pointer — Registers 5CH-5DH) is 
driven with respect to the falling edge of the BCLK 
Input Signal (Pin 39/88). For read accesses, the 
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Memory Output Enable Signal (MOE* — Pin 1/50) 
is asserted at the falling edge of the BCLK at the 
same time as the address is driven onto the 
address bus. For write accesses, the Write Enable 
Signal (WE* — Pin 2/51) is asserted one-half 
BCLK after the address is driven. The Memory 
Output Enable Signal (MOE* — Pin 1/50) and the 
Write Enable Signal (WE* — Pin 2/51) are both 
deasserted (high) on the falling edge of BCLK 
before the end of the SRAM access. This implies 
that the total SRAM access time controls the pulse 
width of these signals. The complete SRAM 
access time is programmed in terms of BCLK- 
Input-Signal (Pin 39/88) periods. 


In the case of a read access to the RAM data buff- 
er, data is clocked into the CL-SH361 by the rising 
edge of the Memory Output Enable Signal 
(MOE* — Pin 1/50). In the case of a write, data is 
held by the CL-SH361 until the deassertion of the 
Write Enable Signal (WE* — Pin 2/51). 


The theoretical maximum Buffer Manager through- 
put is 12 Mbytes/second. The actual throughput is 
a function of the NRZ clock frequency from the disk 
drive, the SRAM speed used or required, the de- 
sired host throughput, the Input-BCLK-Signai (Pin 
39/88) frequency, and the BCLK divider selected 
in the Clock Control Register (Register 7FH). 


4.4 PC XT/AT Interface 


The CL-SH361 provides the capability for direct 
connection to the host bus. The host bus drivers 
can sink up to 24 mA of current and drive a load of 
up to 300 pF. To reduce noise on the ATA bus, the 
host data bus drivers on the CL-SH361 have been 
specifically designed. The drivers turn on at 12 mA 
for a short period of time, then switch to the full 24- 
mA drive capability until the new voltage level is 
reached. This feature will reduce the noise on the 
ATA cable that is associated with high slew-rate 
signals. 


The CL-SH361 uses the BD5/IDE/PCMCIA* Sig- 
nal (Pin 98/47) after reset to select between IDE- 
or PCMCIA-compatible levels on the Host Reset 
Signal and Host Interrupt Signal. The BD5/IDE/ 
PCMCIA* Signal (Pin 98/47) has an internal pull- 
up resistor. If this pin is connected to an externa! 
pull-down resistor after reset, the CL-SH361 will 
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operate with HRST active-high and HINT“ active- 
low (PCMCIA-compatible Mode). If this pin is only 
connected to the data port of the buffer RAM with- 
out an external pull-down resistor, the CL-SH361 
will recognize the high level (internal pull-up) on 
this signal and will operate with HRST* active-low 
and HINT active-high (IDE Mode). The firmware 
can set the mode (IDE or PCMCIA) of operation by 
programming Bit 0 of the IDE/PCMCIA Register 
(Register 6FH). 


4.4.1. PC Transfers 


For transfers between the PC bus and buffer 
memory, data is transferred under DMA or PIO 
control. Transfers are enabled by setting the DMA 
Start Bit (Register 53H, Bit 1). The transfer 
direction is determined by the contents of the PC 
RM* Transfer Direction Bit (Register 53H, Bit 3). 
The contents of the Host Address Pointer are used 
to address the buffer memory. 


During the PC data transfer, the last buffer ad- 
dress that can be accessed is controlled by the PC 
Stop Pointer. This PC Stop Pointer is compared 
with the Host Address Pointer, masked by the con- 
tent of the Buffer Size/Segment Address Register 
(Register 54H). When a match occurs, the PC 
Transfer Done Bit (Register 53H, Bit 2) is set, sig- 
nifying the completion of the transfer to or from the 
PC bus. 


4.4.1.1 PC Direct Memory Access (DMA) 
Operations 


The CL-SH361 operates in DMA Mode for both XT 
and AT protocols. There are two modes of DMA 
operation: Single Transfer per Bus Arbitration and 
Multiple Transfers per Bus Arbitration (EISA Type 
‘B’ Demand Mode). No interrupts to the host are 
generated during DMA transfers. The three con- 
trol bits that select DMA Mode are: the AT Host 
Fixed Disk Register DMAENB (Register 52H, Bit 
4), the Demand Mode DMA Enable Bit (Register 
53H, Bit 7) and the PIO or DMA Select Bit (Regis- 
ter 58H, Bit 3). 


Tables 4—2 and 4-3 on the following page summa- 
rize the use of these bits for XT and AT DMA oper- 
ations. 
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Table 4-2. XT DMA 


Reg 53H, Bit 7 Description 


During the Data Phase, Single Transfer Mode can occur if the host 
enables Bit 0 of the Drive/DMA/Interrupt Enable Register. 


{ During the Data Phase, Multiple Transfer Mode can occur if the host 
enables Bit 0 of the Drive/DMA/Interrupt Enable Register. 


Table 4-3. ATDMA 


—— 58H, Bit 3) Reg. 52H, Bit 4) Reg. 53H, Bit 7 Description 


Single-Transfer DMA enabled 
through the Data Register (1FOH) 
Multiple- Transfer DMA enabled 
through the Data Register (1FOH) 


NOTE: X = Don't care 


4.4.1.1.1 Single-Transfer DMA 


In Single-Transfer DMA Mode, the CL-SH361 as- 
serts DREQ (Pin 49/98) for each transfer. In this 
mode, the host bus is arbitrated for each transfer, 
since the DREQ Signal is deasserted in response 
to the DACK* (Pin 50/99) Signal. 


4.4.1.1.2 Multiple-Transfer DMA (EISA Type 
‘B’ Demand Mode) 


In Multiple-Transfer DMA Mode, the CL-SH361 


asserts DREQ (Pin 49/98) for the length of the 
transfer, but will deassert DREQ to stop an 
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Single-Transfer DMA enabied if 
Bit 0 of the Fixed Disk Register 
(8F6H) is set through the Data 
Register (1FOH) 


Multiple- Transfer DMA enabled if 
Bit 0 of the Fixed Disk Register 
(3F6H) is set through the Data 
Register (1FOH) 


overrun/underrun. If a higher-priority DMA device 
requires the bus, the host can deassert DACK* 
(Pin 50/99) during the transfer; or, if no other 
higher-priority device requests the bus, the host 
may assert DACK* for the length of the transfer. 


4.4.2 PC Host Wait States 


The CL-SH361 also provides circuitry to extend 
the host !/O cycle and insert wait states by assert- 
ing low the IOCHRDY* Signal (Pin 48/97). This cir- 
cuit is only active during programmed I/O host 
transfers. The CL-SH361 inserts wait states in the 
following two ways: 
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1) It can be programmed in the PC Mode Control 
(Register 58H, Bits 0 and 1) to insert wait 
states on any host I/O transfer. This can be 
used to extend the width of the IOR*/IOW* 
pulse, in case of a fast CPU with short IOR*/ 
IOW* pulses. 


Mm 
~— 


When the automatic wait-state generation fea- 
ture is enabled (Register 58H, Bit 2 is set), a 
wait state will be automatically inserted by as- 
serting low the IOCHRDY* Signal (Pin 48/97) 
(only during host I/O transfers to/from buffer 
memory) when the CL-SH361 is not ready for 
the transfer. 


if programmed wait states (see Item 1) are en- 
abled, and if any additional wait states are neces- 
sary, the automatic wait-state circuit will be activat- 
ed. This occurs after the programmed number of 
wait states have been inserted. 


4.4.3. PC Host Auto-Commands 


The CL-SH361 has circuitry to speed up the per- 
formance of the disk controller by decoding write 
commands requiring data transfer from the host to 
the buffer memory, i.e., Format (5XH), Write Buffer 
(E8H), Write or Write Long (3XH). The CL-SH361 
will automatically start accepting data from the 
host, without local microcontroller control, when 
the AT Host Command Register is loaded by the 
host. If interrupts are enabled, the CL-SH361 then 
generates an interrupt to the local microcontroller. 
The Stop Pointer (Registers 5EH and 5FH) is ini- 
tialized to O1FFH. If the Buffer Stop Pointer Dis- 
able (Register 52H, Bit 6) is set, the local micro- 
controller must initialize the Stop Pointer 
(Registers 5EH and 5FH) to enable the compari- 
son of the Host Address Pointer (HAP Registers 
5CH and 5DH) with the Stop Pointer. The CL- 
SH361 Sector Formatter will disconnect from the 
Buffer Manager upon receipt of one of these com- 
mands. It will also disable write access by the local 
microcontroller to Registers 53H, 5CH-5FH, and 
read/write access to Registers 68H and 70H. Ac- 
cess to these registers will be enabled when the lo- 
cal microcontroller writes to Register 73H. The !o- 
cal microcontroller must write to Register 73H to 
enable transfers between the Sector Formaitter 
and the buffer memory. 
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4.4.4 PC Host Long Commands 


If Bit 1 of the command byte is set (for read/write 
long commands), then all buffer memory transfers 
to/from the host will exceed the Stop Pointer (Reg- 
isters 5EH and 5FH) by the count of ECC bytes. 
Initially, the Stop Pointer is set at the end of the 
data field. When the Host Address Pointer (Regis- 
ters 5CH and 5DH) matches the Stop Pointer, the 
internal FIFO will be emptied of the word-width 
data. The ECC bytes will then be transferred in 
Byte Mode, and the HAP will be incremented by 
the number of ECC bytes, as defined in the Host 
32-/56-/88-Bit ECC Select (Register 71H, Bit 3-2). 


4.4.5 PC Host Master/Slave Operation 


The CL-SH361 provides circuitry to support two 
embedded AT or XT disk controller drives in a sys- 
tem. There are two bits (Bits 1 and 2) in Register 
52H for this configuration. The Master/Slave Mode 
Enable Bit (Register 52H, Bit 1) must be set to en- 
able the two-disk-drive master/slave configuration. 
The Master/Slave Select Bit (Register 52H, Bit 2) 
configures the disk drive as a master or slave. For 
the PC AT — if this bit is set — the disk controller 
responds as a Slave (i.e., it responds when the disk 
drive number in the AT Host Drive/Head Register 
[Port 1F6H] is set to a 1). The register files in both 
controllers, when configured as master and slave, 
will be written to by the host, no matter which drive 
is selected in the AT Host Drive/Head Register. 
However, only the selected disk drive will execute 
the command. The only exception is during power- 
up or diagnostic commands; both the master and 
the slave will run the diagnostics, but the master 
will return the status for both drives to the host. For 
the PC XT, the controller responds as a slave if Bit 
2 of the host DRV/DMA/IRQ Enable Register is 
set, and Register 52H, Bit 2 is set. 


In addition to these features, the CL-SH361 also 
provides the local microcontroller with PDIAG* and 
DASP* support in the Auxiliary Control 1 Register 
(Register 4FH, Bits 2-1). This register may be pro- 
grammed by the local microcontroller to implement 
ATA-compatible multiple-drive operation. 
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5. DETAILED INTERNAL REGISTER DESCRIPTION 


The register tables refer to the following register types: R/W = Read/Write, R = Read only, W = Write only. 
5.1. Register 9FH: Buffer Start Address High Register (BSAH) (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83), or Buffer Manager Reset (Register 59H, Bit 0). 


Bits 7-0 —_‘ This register is the high-order byte of the buffer memory start address. 


5.2 Register BFH: Buffer Start Address Low Register (BSAL) (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83), or Buffer Manager Reset (Register 59H, Bit 0). 


Bits 7-0 This register is the low-order byte of the buffer memory start address. 


5.3 Register DFH: Buffer End Address High Register (BEAH) (Read/Write) 


This register is set to FFH by the assertion of RST“ (Pin 34/83), or Buffer Manager Reset (Register 59H, 
Bit 0). 


Bits 7-0 —_ This register is the high-order byte of the buffer memory end address. 


5.4 Register FFH: Buffer End Address Low Register (BEAL) (Read/Write) 


This register is set to FFH by the assertion of RST” (Pin 34/83), or Buffer Manager Reset (Register 59H, 
Bit 0). 


Bits 7-0 This register is the low-order byte of the buffer memory end address. 


5.5 Register 48H: Auxiliary Control 0 Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bit 0 RW BUFFER POINTER AUTO-INCREMENT ENABLE: This bit, when set, allows 
auto-incrementing of the buffer address when the microcontroller reads or 
writes Register 68H or 70H for buffer accesses. 


Bit 1 — Reserved. 
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5.5 Register 48H: Auxiliary Control 0 Register (Read/Write) (cont) 


Bit 2 R SYNCHRONIZATION TIME-OUT ERROR: This bit is set after the timer limit 
that is held in the Synchronization Byte-Count Limit Register (Register 76H) 
has expired, and read synchronization has not occurred. This bit is reset by 
Register 71H, Bit 5. 


Bit 3 R TWO INDEX DETECTED STATUS: This bit is set when the Two Index Detec- 
tion circuit has been enabled and Two Index edges have been detected without 
a data transfer between the formatter and buffer. This bit is reset when the Two 
Index Detection Mode is disabled (Register 48, Bit 6 = 0) or when the Two In- 
dex Detection circuit is armed. 


Bit 4 R/W CLEAR FIXED DISK REGISTER, BIT 0: This bit is used to reset the DMA En- 
able Control Bit in the Fixed Disk Register (3F6H). To reset the Fixed Disk Reg- 
ister, Bit 0, set and clear this bit. This bit is reset by HRST*/HRST (Pin 53/2), 
RST* (Pin 34/83), and a host-programmed reset. 


Bit 5 R PC HOST PROGRAM RESET: This bit is set by a host program reset. This bit 
is reset by RST* (Pin 34/83) or by setting the Clear PC Host Program Reset Bit 
(Register 48H, Bit 7). This bit is set for the duration of the host-program-reset 
active time. 


Bit 6 R/W TWO INDEX DETECTION MODE ENABLE: When this bit is set, the Two In- 
dex Detection Mode is enabled. When the Two Index Detection Mode is en- 
abled, the index detection circuit is armed or rearmed by the WCS. The detec- 
tion circuit is armed if the WCS Control Field has both Read Gate and Data 
Transfer off and Bit 5 of the Count Field is set. Once the circuit is armed, it re- 
mains armed until one of the following three events happens: 1) data transfer 
occurs between the formatter and buffer; 2) two index pulses are detected and 
the formatter is stopped; or 3) the Two Index Detection Mode Enable Bit is re- 
set. When the detection circuit is armed, and Two Index edges are detected, 
the Two index Detected Status Bit is set (Register 48H, Bit 3). The Status Bit 
remains set until the Two Index Detection Mode is disabled. When the Two In- 
dex Detected Status Bit is set, it asserts the ‘stopped’ signal to stop the For- 
matter Operation. This, in turn, disarms the detection circuit. This bit is reset by 
RST* (Pin 34/83) and Register 71H, Bit 5. 


Bit 7 R BYTE READY: When this bit is set, it indicates that a scheduled buffer memory 
access is completed, and that another scheduled buffer memory access may 
be started. 

Bit 7 WwW CLEAR PC HOST PROGRAM RESET: When this bit is set, it will clear the PC 


Host Program Reset Bit (Register 48H, Bit 5). 
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5.6 Register 4DH: 68H AND 70H Read Data Register (Read Only) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bits 7-0 R BUFFER DATA SHADOW REGISTER: When the microcontroller reads Reg- 
isters 68H and 70H, the contents of the buffer memory data bus will be cap- 
tured in Register 4DH for future reference. This register is reset by assertion of 
RST* (Pin 34/83) or when the Formatter Reset Bit (Register 71H, Bit 5) is set. 


5.7 Register 4EH: Sector Size Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 R/W Writing to this register sets the number of 256-byte data blocks transferred by 
the Disk Formatter when the Inhibit Carry Bit (Register 7AH, Bit 7) is used. If 
this register is set (or reset) to OOH, the Inhibit Carry function will be compatible 
with the CL-SH130. The value programmed, plus one, is the number of the 
Current Sequencer Count Field underflows that will be inhibited. For a 532-byte 
data field, set the WCS Count value to 13H (19), the Sector Size (Register 
4EH) to 01H, and set the three most-significant bits of the Next Address Field 
Register of the WCS to 100 when the Data Transfer Bit (WCS Control! Field 
Register, Bit 0) is set. For a 4096-byte data field, set the WCS count value to 
FFH, the sector size to OEH (14), and set Inhibit Carry. 


5.8 Register 4FH: Auxiliary Control 1 Register (Read/Write) 


Bit 0 RAW ADVANCED MULTISECTOR/MULTISECTOR:®: When set, the sequencer will 
use the Sector Remaining Counter, Sector Target and Sector Count Register 
to control the Multisector Read/Write Operations. This will use the embedded- 
data-split counts in the ID field and the automatic increment of the sector num- 
ber to control the multisector operations without the intervention of the micro- 
controller. When reset, the microcontroller must update the WCS for every sec- 
tor of a Multisector Read/Write Operation. This bit is reset by the assertion of 
RST* (Pin 34/83). 


Bit 1 RAW PASS DIAGNOSTICS: This bit controls the PDIAG* (Pin 27/76) function that 
is used for master/slave operation on embedded AT drives. A read of this bit 
inputs the state of the pin, while a write of this bit drives the pin. 


Bit 2 R/W SLAVE PRESENT: This bit controls the 1-CLK/DASP* (Pin 28/77) Pin when it 
is configured to operate as DASP* (Register 7FH, Bits 3 and 4 are not 00). The 
DASP* function is used for master/slave operations on embedded AT drives. 
A read of this bit inputs the state of the pin, while a write of this bit drives the pin. 
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5.8 Register 4FH: Auxiliary Control 1 Register (Read/Write) (cont.) 


Bit 3 R/W 
Bit 4 RAW 
Bit 5 R/W 
Bit 6 R/W 
Bit 7 RAW 


CLEAR XT BUSY ENABLE (PC/XT Mode only): This bit, when set, will allow 
the automatic clear of the Busy Bit (Register 55H, Bit 7) in the XT Mode when 
the host reads the Completion Status Byte at the end of all commands. This bit 
is reset by the assertion of RST* (Pin 34/83). 


DISABLE PIN PULL-UP RESISTORS: This bit, when set, will disable the pull- 
up resistors on HCSO* (Pin 47/96), HA9/HCS1* (Pin 46/95), INPUT2/HOS- 
TINT* (Pin 5/54), PDIAG* (Pin 27/76), and 1FCLK/DASP* (Pin 28/77). 


LOCAL INTERFACE POWER DOWN: The CL-SH361 will wake up from this 
mode by a write to the AT Command Register or XT Select Register, or asser- 
tion of HRST*/HRST (Pin 53/2), RST* (Pin 34/83), or by setting the Reset Bit 
in the AT Fixed Disk Register (3F6, Bit 2). This bit is locked by a write to the 
AT Command Register or the XT Select Register. It can be unlocked by a write 
to Register 73H. 


HOST ATA POWER DOWN: The CL-SH361 will wake up from this mode by 
assertion of HRST*/HRST (Pin 53/2) or RST* (Pin 34/83), or by setting the Re- 
set Bit in the AT Fixed Disk Register (3F6, Bit 2). 


HOST DEEP SLEEP MODE: The CL-SH361 will wake up from this mode by 
assertion of HRST*/HRST (Pin 53/2) or RST* (Pin 34/83). 


5.9 Register 50H: PC Interrupt Status Register (Read Only) 


This register is reset by the assertion of HRST*/HRST (Pin 53/2), RST* (Pin 34/83), or a host-pro- 
grammed reset. Bit 4 of this is reset by RST“ (Pin 34/83) only. All bits are cleared by a read of this register. 


Bit 0 R 
Bit 1 R 
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PC TRANSFER DONE: When this bit is set, it indicates the completion of a 
host transfer [i.e., the PC Stop Pointer, (Registers 5EH-5FH), is equal to the 
Host Address Pointer, (HAP — Registers 5AH and 5Bh)]. After this bit is set, 
the Host Address Pointer will read one byte more than the value of the PC Stop 
Pointer. This bit is reset when the host writes to the Command Register. in the 
Master/Slave Mode, this bit is only reset by a write to the Command Register if 
the DRV Select Bit matches the master/slave select configuration. This bit is 
the same as Register 53H, Bit 2. 


PC TRANSFER OVERRUN/UNDERRUN DETECTED: When this bit is set, it 
indicates that a data transfer between the host and the buffer memory did not 
function properly. This bit is set when the IOCHRDY* Signal (Pin 48/97) is as- 
serted low, and the rising (trailing) edge of the IOW* Signal (Pin 52/1) or the 
IOR* Signal (Pin 51/100) was detected. This bit is reset when the host writes 
to the Command Register. 
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5.9 Register 50H: PC Interrupt Status Register (Read Only) (cont.) 


Bit 2 R PC SELECTION DETECTED: In the XT Mode, this bit is set when the host 
writes to Port 2. In PC AT Mode, this bit is set when the host writes to the AT 
Command Register (47H/67H). 


Bit 3 R AT STATUS READ DETECTED: In AT Mode, this bit is set if the host reads 
the Primary Controller/Drive Status Register (1F7H or 177H) the first time fol- 
lowing data transfers between the host and the FIFO. It is not set if the host 
reads the Alternate Controller/Drive Status Register (3F6H). in addition to the 
reset conditions described above, it is also cleared when the host writes to the 
Command Register. 


Bit 4 R PC RESET DETECTED: This bit is set by assertion of the Host Reset Signal 
HRST*/HRST (Pin 53/2) or a host-programmed reset, i.e., when the XT Host 
writes to Port 1 or the AT Host sets the RESET Bit (AT Host Fixed Disk Regis- 
ter, Bit 2). This bit is set for the duration of the host reset condition. 


Bit 5 — Not used; status indeterminate. 
Bit 6 _ Not used; status indeterminate. 
Bit 7 — Not used; status indeterminate. 


5.10 Register 51H: PC Interrupt Enable Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bit 0 RAW PC TRANSFER DONE ENABLE: Wher this bit is set, it will cause the INT* 
Signa! (Pin 4/53) to be asserted low, when the PC Transfer Done Bit (Register 
50H, Bit 0 and Register 53H, Bit 2) is set. 


Bit 1 RW PC TRANSFER OVERRUN/UNDERRUN ENABLE: When this bit is set, it will 
cause the INT* Signal (Pin 4/53) to be asserted low, when the PC Transfer 
Overrun/Underrun Detected Bit (Register 50H, Bit 1) is set. 


Bit 2 R/W PC SELECTION ENABLE: When this bit is set, it will cause the INT* Signal 
(Pin 4/53) to be asserted Jow when the PC Selection Detected Bit (Register 
50H, Bit 2) is set. 


Bit 3 RAW AT STATUS READ ENABLE: When this bit is set, it will cause the INT* Signal 
(Pin 4/53) to be asserted low, when the AT Status Read Detected Bit (Register 
50H, Bit 3) is set. 
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5.10 Register 51H: PC Interrupt Enable Register (Read/Write) (cont.) 


Bit 4 R/W PC RESET ENABLE: When this bit is set, it will cause the INT* Signal (Pin 4/ 
53) to be asserted low, when the PC Reset Detected Bit (Register 50H, Bit 4) 
is set. 

Bit 5 —_— Not used; status indeterminate. 

Bit 6 — Not used; status indeterminate. 

Bit 7 —_— Not used; status indeterminate. 


5.11 Register 52H: Miscelianeous Control/Status Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bit 0 R/W MOE* DISABLE: When this bit is set, the buffer memory MOE* Signal (Pin 1/ 
50) is disabled from being asserted low. This is intended to support switch 
reads (via 70H) on the buffer memory data bus. This bit is reset by the assertion 
of RST* (Pin 34/83). 


Bit 1 R/W MASTER/SLAVE MODE ENABLE: When this bit is set, it enables the ability 
to daisy-chain two separate XT or AT interfaces together, one configured as 
master and the other as slave. 


Bit 2 R/AW MASTER/SLAVE SELECT: When Bit 1 of Register 52 is set, this bit configures 
the CL-SH361 as master or slave. When this bit is reset, the CL-SH361 is con- 
figured as a master; when set, it is configured as a slave. The master responds 
to a Drive 0 select, and the slave responds to a Drive 1 select. For the PC AT, 
on a diagnostic command, both the master and slave respond; only the master 
is enabled to report status to the host. 


Bit 3 R/W HCS1 MODE ENABLE: (AT Mode only) When this bit is set, Pin 45/94 is the 
HCS1* Input; when this bit is reset, Pin 46/95 is the PC Address Line 9 Input. 


Bit 4 RW AT HOST FIXED DISK REGISTER DMAENB: This bit is valid only in the PC 
AT Mode, and when the DMA Mode is enabled (i.e., Register 58H, Bits 3 and 
7 are reset). When this bit is set, it allows Bit 0 of the AT Host Fixed Disk Reg- 
ister to control the enabling of the DMA channel. This bit should be set prior to 
enabling the DMA Mode (Register 58, Bit 3). 


Bit 5 R AT DMAEN: This bit reflects Bit 0 of the AT Host Fixed Disk Register. The 
Fixed Disk Register is a write-only host register that the local microcontroller 
can monitor through this read-only status bit. 
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5.11 Register 52H: Miscellaneous Control/Status Register (Read/Write) (cont.) 


Bit 6 RAW BUFFER STOP POINTER DISABLE: When set, this bit disables comparison 
of the PC Stop Pointer (Registers 5EH and 5FH), until Register 5EH is loaded. 


Bit 7 R/W TEST MODE ENABLE: This bit is reserved by Cirrus Logic for test purposes. 
The user should program this bit to a logical zero. 


5.12 Register 53H: Buffer Transfer Control Register (Read/Write) 


This register is reset by the assertion of HRST*/HRST (Pin 53/2), RST* (Pin 34/83), or Buffer Manager 
Reset (Register 59H, Bit 0), Bit 7 of this register is reset by RST* (Pin 34/83) only. 


Bit 0 R/W DUAL-BUFFER CHIP ENABLE: When this bit is set, it allows BA15/CE2* (Pin 
90/39) to operate as a second buffer chip enable for 64K buffers. This means 
CE1* (Pin 3/52) is connected to the first 32K chip enable and BA15/CE2* (Pin 
90/39) to the second 32K chip enable. 


Bit 1 RAW DMA START: When set, the CL-SH361 will start a DMA transfer; the direction 
of the transfer is programmed in the PC RMW* Transfer Direction (Bit 3). 


Bit 2 R PC TRANSFER DONE: When this bit is set, it indicates the completion of a 
host transfer (i.e., the PC Stop Pointer, Registers 5EH-5FH, is equal to the 
Host Address Pointer — Registers 5AH and 5Bh). After this bit is set, the Host 
Address Pointer will read one byte more than the value of the PC Stop Pointer. 
This bit is the same as Register 50H, Bit 0. 


Bit 3 R/W PC R/W* TRANSFER DIRECTION: This bit indicates the information-transfer 
direction on the PC bus in both the Programmed !/O (PIO) and DMA Transfer 
Modes. When this bit is reset, information is transferred to the CL-SH361. 


Bit 4 R/W BUFFER/DISK R/W* TRANSFER DIRECTION: This bit indicates the informa- 
tion-transfer direction to/from the Sector Formatter when a disk data transfer is 
initiated by the Sector Formatter. When this bit is set, the data-transfer direction 
is from the Sector Formatter to the buffer memory. When this bit is reset, the 
data-transfer direction is from the buffer memory to the Sector Formatter. 


Bit 5 R/W BUFFER CHIP ENABLE: When this bit is set, it asserts the CE* Signal (Pin 3/ 
52 or 90/39) until this bit is reset. This bit is used to enable buffer memory for 
Read/Write Operations. This bit may be set when both the disk and host are 
idle, and a Read 70H and Write 70H Operation is performed. 


Bit 6 RAW BUFFER OUTPUT ENABLE: When this bit is set, it asserts the MOE* Signal 
(Pin 1/50). This bit is used for a Read 70 Operation to improve the buffer ac- 
cess time for fast processors. 
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5.12 Register 53H: Buffer Transfer Control Register (Read/Write) (cont.) 


Bit 7 R/W DEMAND MODE DMA ENABLE: This bit, when set, enables the DMA logic 
to assert DREQ (Pin 49/98) for the length of the transfer or de-assert DREQ for 
underrun/overrun control. In this mode, multiple transfers can occur without ar- 
bitrating the host bus. This bit is reset by RST* (Pin 34/83) only. 


5.13 Register 54H: Buffer Size/Segment Address Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 RW This register can operate in two modes. In the first mode, the value stored in 
this register represents the maximum external static RAM size to be controlled 
by the CL-SH361. For example, if a 32K buffer is attached, then this register is 
loaded with 7FH. The HAP and DAP Address Pointers access the buffer using 
BAO-14. When the HAP or DAP reaches 7FFFH, the pointer will roll over to 
OOOOH on the next access. BA15 will always be zero in this example. 


In the second mode, this register specifies a buffer segmentation size. The 
smallest size is 4K. For example, with an attached buffer size of 32K and seg- 
ment sizes of 4K, this register would be loaded with OFH. This would create 
eight 4K segments 0000-OFFFH, 1000-1FFFH, 2000-2FFFH, 3000-3FFFH, 
4000-4FFFH, 5000-5FFFH, 6000-6FFFH, 7000-7FFFH. Each segment can be 
accessed by setting the upper four bits of the HAP and DAP to the desired seg- 
ment address. In this configuration, once the address pointer reaches XFFFH, 
the next address will roll over to XOOOH. 


For an AT interface auto-command sequence, the HAP pointer will be set to 0000H, regardiess of 
the previous segment address. 


The following table defines the allowable values that can be programmed into Register 54H. 


00H = 256 bytes 
01H = 512 bytes 
03H = 1K bytes 
07H = 2K bytes 
OFH = 4K bytes 
1FH = 8K bytes 
3FH = 16K bytes 
7FH = 32K bytes 
FFH = 64K bytes 


NOTE: This register cannot be modified while the buffer is being accessed. 
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Registers 55H-57H are XT/AT Registers. Piease refer to Section 7, Local Microcontroller-Host 
Interface. 


5.14 Register 58H: PC Mode Control Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 1-0 RAW PC WAIT STATE: These bits specify the number of buffer memory cycles for 
which IOCHRDY* (Pin 48/97) will be asserted low for programmed I/O (PIO) 
transfers. These bits are reset by assertion of RST* (Pin 34/83). 
00 = no buffer memory cycles 
01 = 1-2 buffer memory cycle 
10 = 2-3 buffer memory cycles 
11 = 3-4 buffer memory cycles 


Bit 2 R/W AUTO-WAIT-STATE GENERATION ENABLE: When this bit is set, wait- 
states will be generated automatically for programmed I/O transfers between 
the host and the buffer memory when the CL-SH361 is not ready to transfer 
data. When auto-wait-state generation is enabled, IOCHRDY* (Pin 48/97) is 
negated when both the CL-SH361 is ready and the programmed number of 
wait states in the bus cycle specified by Register 58H, Bits 1-0, are generated. 
This bit is reset by assertion of RST* (Pin 34/83). 


Bit 3 R/iW PIO or DMA SELECT: (PC/AT Mode only) When this bit is set, Programmed 
/O(PIO) is selected. When the AT DMA Mode is selected, the PC can hand- 
shake the DREQ Line with either a HCSO* or a DACK*. By setting Register 
52H, Bit 4, in AT DMA Mode, the PC can directly control the DMAEN of the 
DMA channel through Bit 0 of the Fixed Disk Register; (the local microcontroller 
can monitor this bit through Register 52H, Bit 5). This bit is set by assertion of 
RST* (Pin 34/83). 


Bit 4 RAV ENABLE AUTO-INTERRUPT UPON START OF PC DATA TRANSFER: (PC 
AT Mode only) When this bit is set, the CL-SH361 generates an interrupt to the 
host when the local microcontroller initiates a host data transfer. This is done 
by setting the Start DMA Bit (Register 53H, Bit 1) in the Buffer Transfer Control 
(Register 53H); or, if this bit is set, it is done by writing to Register 5EH. This bit 
is set by assertion of RST* (Pin 34/83). 


Bit 5 R/W DISABLE AUTO-COMMAND EXECUTION: When this bit is set, it disables au- 
tomatic execution of write, write long, write buffer, and format commands. 
When this bit is set, it also disables the automatic transfer of ECC bytes for 
read/write long commands. This bit is reset by assertion of RST* (Pin 34/83). 


Bit 6 RAW 8-/16-BIT DATA: (PC/AT Mode only) When this is set, it selects 16-bit data 
transfer to/from the PC. This bit is set by the assertion of RST* (Pin 34/83). 
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5.14 Register 58H: PC Mode Control Register (Read/Write) (cont.) 


Bit 7 R/W XT/AT SELECT: This bit controis which host interface is active, XT or AT. 
When this bit is set, the PC XT Mode is selected. This bit is reset by the asser- 
tion of RST* (Pin 34/83). 


5.15 Register 59H: Buffer Manager/PC Reset Control Register (Read/Write) 


Bit 0 R/W BUFFER MANAGER RESET: When this bit is set, it holds all registers associ- 
ated with the Buffer Manager and PC functions in the Reset State until this bit 
is reset. Assertion of RST* (Pin 34/83) will also set this bit. A write to this reg- 
ister resets the Host Address Pointer (HAP) and the Disk Address Pointer 
(DAP), Registers 5AH-5DH and sets the PC Stop Pointer (Registers 5EH and 
5FH), to a 01FFH. 

CAUTION: Any write to this register also resets the PC Interface Operation. Bit 0 
must be reset to execute PC AT auto-commands. 


Bits 7-1 _— Reserved. 


5.16 Register 5AH: Disk Address Pointer High Register (DAPH) (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83) or Buffer Manager Reset (Register 59H, Bit 0). 


Bits 7-0 R/W DISK ADDRESS POINTER HIGH BYTE: These bits are the high-order byte of 
the buffer memory address for disk and microcontroller accesses. 


5.17 Register 5BH: Disk Address Pointer Low Register (DAPL) (Read/Write) 


This register is reset by the assertion of RST” (Pin 34/83), or the Buffer Manager Reset (Register 59H, 
Bit 0). 


Bits 7-0 R/W DISK ADDRESS POINTER LOW BYTE: These bits are the low-order byte of 
the buffer memory address for disk and microcontroller accesses. 
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5.18 Register 5CH: Host Address Pointer High Register (HAPH) (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83), or the Buffer Manager Reset (Register 59H, 
Bit 0). 


Bits 7-0 R/W HOST ADDRESS POINTER HIGH BYTE: These bits are the high-order byte 
of the buffer memory address for host accesses. This register is also reset 
when an auto-command is issued. 


5.19 Register 5DH: Host Address Pointer Low Register (HAPL) (Read/Write) 


This register is reset by the assertion of RST* (Pin 34/83), or the Buffer Manager Reset (Register 59H, 
Bit 0). 


Bits 7-0 RW HOST ADDRESS POINTER LOW BYTE: These bits are the low-order byte of 
the buffer memory address for host accesses. This register is also reset when 
an auto-command is issued. 


5.20 Register 5EH: Stop Pointer High Register (SPH) (Read/Write) 


This register is set to 01H by the assertion of RST* (Pin 34/83), or the Buffer Manager Reset (Register 
59H, Bit 0). 


Bits 7-0 R/W STOP POINTER HIGH BYTE: These bits are the high-order byte of the Stop 
Pointer (SP). It is used to detect the end of the host data transfer. It is compared 
with the Host Address Pointer (HAP — Register 5CH and 5DH). When they are 
equal, the Host Transfer Done Bit (Register 50H, Bit 0, Register 53H, Bit 2) is 
set and the transfer is halted. If a new value is programmed in this register, a 
new transfer cycle will begin again if the DMA Start Bit (Register 53H, Bit 1) is 
still set. This register is also set to 01H when one of the auto-commands is is- 
sued. 


5.21 Register 5FH: Stop Pointer Low Register (SPL) (Read/Write) 


This register is set to FFH by the assertion of RST* (Pin 34/83), or the Buffer Manager Reset (Register 
59H, Bit 0). 


Bits 7-0 RAW STOP POINTER LOW BYTE: These bits are the low-order byte of the Stop 
Pointer (SP). It is used to detect the end of the host data transfer. It is compared 
with the Host Address Pointer (HAP — Register 5CH and 5DH). This register 
is also set to FFH when one of the auto-commands is issued. 
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5.22 Register 68H: Scheduled Buffer Access Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83), or Buffer Manager Reset (Register 59H, Bit 0). 


Bits 7-0 R/W SCHEDULED BUFFER DATA: This register is used to access the buffer mem- 
ory (using the Disk Address Pointer), or to access switches on the buffer data 
bus (using MOE* Disable — Register 52H, Bit 0). Auto-incrementing of the 
DAP can be enabled by setting the Buffer Pointer Auto-increment Enable (Reg- 
ister 48, Bit 0). If this register is being used to write data to the buffer memory, 
the following algorithm must be used: 

1. First, by program construction or by reading an active value on the Byte Ready Bit 
(Register 48H, Bit 7), verify that the scheduling mechanism is ready to accept a 
byte of data. 


2. Next, if the DAP is not pointing to the desired buffer memory address, write the de- 
sired address to the DAP. 


3. Write the byte to this register. Byte Ready will be reset until the byte has been writ- 
ten, and the DAP has been incremented (If Auto-incrementing is enabled). 


4. If another byte is desired, repeat this loop. 


If this register is being used to read data from the buffer memory, the following 
algorithm must be used: 


1. First, by program construction or by reading an active value on the Byte Ready Bit 
(Register 48H, Bit 7), verify that the scheduling mechanism is ready to read a byte 
of data. 


2. Next, if the DAP is not pointing to the desired buffer memory address, write the de- 
sired address to the DAP. 


3. Read this register. The data received will be data from a previous Scheduled Read 
or Scheduled Write Operation. 


4. By program construction or by reading an active value on the Byte Ready Bit (Reg- 
ister 48H, Bit 7), verify that the scheduling mechanism is ready to read a byte of 
data. When the scheduling mechanism is ready to read a byte of data, the desired 
byte is available to be read. Also, the DAP has been incremented (If auto-incre- 
menting is enabled); therefore, a final read of this register will provide the desired 
data and trigger another scheduled read. If another byte is desired, repeat this 
loop; however, the next scheduled read will return the byte from the address point- 
ed to by the incremented DAP (if auto-incrementing is enabled). If switches are 
used on the buffer data bus, the switches should be pulled up with 270K ohm re- 
sistors, and pulled down with 27K ohm resistors. To read the switches, set MOE* 
Disable, wait a time constant (about 3 ys), and then read this register twice. Note 
that the normal scheduling mechanism is still used. 
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5.23 Register 69H: Sector Status Register (Read Only) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bit 0 R END OF TRACK: This bit is set when the End of Track Bit in the ID Flag/MS 
Split Byte is set. It is reset after the read of this register. 


Bit 1 R DEFECT: This bit is set when Defect Bit in the ID Flag/MS Split Byte is set. It 
is reset after the read of this register. 


Bit 2 R HOST RESET: This bit shows the state of the HRST*/HRST (Pin 53/2) Signal. 


Bit 3 R IDE/PCMCIA STATUS: This bit shows the state of Bit 0 in the IDE/PCMCIA 
Control Register (Register 6FH — Write Only). 


Bits 7-4 —_ Reserved. 


5.24 Register 69H: Increment Sector Count Register (Write Only) 


Bits7-0 — Awrite to this register increments the Sector Count Register (Register 6BH) by 
1. This function is always enabled, even if the sequencer is stopped. The 
RRCLK (Pin 37/86) must be running in order for the Sector Count Register to 
increment. 


5.25 Register 6AH: Sector Target Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 R/W This register is loaded with the starting sector number to be read or written to/ 
from the disk. The sequencer verifies the target sector by comparing the !D 
field from the disk with the internal ID values. The Sector Target Register is 
used as the source for the sector |D search. This register is incremented auto- 
matically, after the ECC is processed, for each sector. 


5.26 Register 6BH: Sector Count Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 R/W This register is loaded with the number of sectors to be processed. At the end 
of each sector, this register is decremented at the beginning of the ‘process 
ECC time.’ Given the proper branch conditions, when this register is equal to 
00H, it informs the sequencer of the last sector to be processed and will stop 
the sequencer at the end of the current sector. 
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5.27 Register 6CH: React Branch Register (Read/Write) 


This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bits 4-0 R/W BRANCH ADDRESS: Writing Bits 4-0 will cause the sequencer RAM to jump 
to this address when a branch condition is programmed and met. 


Bits 7-5 —_ Reserved. 


5.28 Register 6DH: Sector Remaining Counter MSB Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 3-0 R/W This register is loaded with the length, in bytes, of the sector data field. For AT 
drives, the normal data length is 512 bytes. 


Bits 7-4 —_— Reserved. 


5.29 Register 6EH: Sector Remaining Counter LSB Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 RAW This register is loaded with the length, in bytes, of the sector data field. For an 
AT drive, the normal data length is 512 bytes. 


5.30 Register 6FH: Revision Register (Read Only) 


Bits 7-0 R This register contains a revision code. 


5.31 Register 6FH: IDE/PCMCIA Control! Register (Write Only) 


Bit 0 W IDE/PCMCIA SELECT: When this bit is set, the polarity of the host interface 
signals HRST*/HRST (Pin 53/2) and HINT/HINT* (Pin 41/90) is configured to 
IDE Mode. When this bit is reset, the polarity of these signals is configured to 
PCMCIA-compatible Mode. 


Bits 7-1 _ Reserved. 
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5.32 Register 70H: Unscheduled Buffer Access Register (Read/Write) 


Bits 7-0 RW A Register 70H decode will internally bridge the buffer data bus and the multi- 
plexed data address bus, allowing the microcontroller to access the buffer 
memory. The DAP Pointer is used to access the buffer. Read data from the 
buffer will also be latched into Register 40H. MOE* Disable (Register 52H, Bit 
0) allows the static value of the buffer data bus (switch read) to be accessed. 
To access the buffer through this register, there must be no PC or disk trans- 
fers in progress as this is an unscheduled access port. Also, the read or write 
of this register will automatically increment the Disk Address Pointer if the Buff- 
er Pointer Auto-increment Enable Bit (Register 48H, Bit 0) is set. 


5.33 Register 71H: ECC Control Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bit 0 R/W HARDWARE CORRECTION ENABLE: When set, this bit enables the on-the- 
fly correction circuitry. Resetting this bit saves the syndrome in the internal cor- 
rection register, which can be read through Register 72H in 8-bit symbols. 


Bit 1 RW SYNDROME SHIFT CONTROL: The function of this bit depends on Bit 0 of 
Register 71H. If Bit 0 is set, the internal on-the-fly correction circuitry is en- 
abled, and Bit 1 is a don’t care bit. If Bit 0 is reset, the ECC error can be cor- 
rected via firmware by reading the 10-byte syndrome from Register 72H in 8- 
bit segments. Setting Bit 1 will shift the syndrome by eight bits. This bit is 
cleared automatically after the shift is completed. 


Bits 3-2 RW HOST 32-/56-/88-BIT ECC SELECT: (PC/AT Mode only) This bit is primarily 
used for long commands. These two bits set the transfer length for the ECC 
bytes with the host as follows: 

Bit3 


Register 71H Bit 2 


32-Bit (4 bytes) 
88-Bit (11 bytes) 
56-Bit (7 bytes) 


NOTE: The formatter always uses 88-bit ECC. These bits are for host ‘long’ 
transfers only. 


Bit 4 R/AW ENABLE SECTOR BRANCH: When set, this bit will cause the sector input to 
be OR'ed with the index so that the sequencer branch on index-or-sector com- 
mand may be triggered by either index or sector. 
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5.33 Register 71H: ECC Control Register (Read/Write) (cont.) 


Bit 5 RAW CHIP RESET: Assertion of the RST* Pin will set this bit along with Bit 0 of Reg- 
ister 59H. If this bit is set by the microcontroller, then the Formatter Sequencer 
is stopped and only the following Formatter Registers are reset: 48H — Bits 2 
and 6, 49-4DH, 71H, 74H, 75H, 78-7AH and 7D-7EH. 


Bit 6 R/W INPUT2 (Pin 5/54) EDGE TRANSITION DIRECTION: When this bit is reset, 
the edge of INPUT2 that causes a trigger is high to low; when this bit is set, it 
is low-to-high. This bit is reset by assertion of RST” only. 


Bit 7 _ Reserved. 


5.34 Register 72H: Syndrome Shift Register (Read Only) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 R The data read from this register is only valid when the Hardware Correction En- 
able Bit (Register 71H, Bit 0) is reset. Use this register in conjunction with Reg- 
ister 71H, Bit 1 (Syndrome Shift Control), after a Data Read Operation and an 
ECC error. The 10-byte syndrome can be read by the local microcontroller, 
through this register, to attempt a firmware correction. 


5.35 Register 72H: Correction Done Reset Register (Write Only) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 W A write to this register resets the Correction Done Status Bit in Register 79H, 
Bit 4. 


5.36 Register 73H: Auto-Command ‘Lock’ Release Register (Write Only) 


Bits 7-0 W AUTO-COMMAND ‘LOCK’ RELEASE: A write to this register unlocks the 
Buffer Manager Registers. The registers were locked when the host issued an 
auto-command. Register 4FH, Bit 5 (Local interface Power Down) is locked un- 
til a write to Register 73H. The other affected registers are 53H, 5CH-5FH, 68H 
and 70H. 
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5.37 Register 74H: Offset Count Register (MSB) (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bits 7-0 R/W This register contains the high-order byte of the maximum number of shifts to 
be performed by the hardware, before the error pattern is found. The Offset 
Registers (Registers 74H and 75H) are to be set to [(number of data bits - 8)/ 
2] +1. For 512-byte sectors, the offset value is O7FDH. 


5.38 Register 75H: Offset Count Register (LSB) (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bits 7-0 RAW This register contains the low-order byte of the maximum number of shifts to 
be performed by the hardware before the error pattern is found. 


5.39 Register 76H: Synchronization Byte-Count Limit Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 R/W This register holds the byte-count limit for the NRZ read data synchronization 
timer. This value is programmable from 0 to 255. Refer to the description of the 
Count/Start Synchronization Timer/Two Index Timer Bit (Bit 5 of the WCS 
Count Field). When the timer has been activated, the value is decremented for 
each byte time that passes. If the value reaches zero, the Synchronization 
Time Out Error Bit (Register 48H, Bit 2) is set. Reading this register provides 
the running count (if the timer is active), or the programmed limit if the timer is 
inactive. 


5.40 Register 77H: Formatter Mode Selection Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bit 0 R/W ENABLE LOCAL MICROCONTROLLER HOST AND DISK INTERRUPTS: 
This bit, when set, configures Host Interrupts (Register 50H) to the HOSTINT* 
(Pin 5/54) and Disk Interrupts (Register 7DH) to the INT*/DISKINT* (Pin 4/53). 
When this bit is reset, all interrupts affect the INT*/DISKINT* (Pin 4/53). 


Bit 1 R/W PC REGISTER FILE ACCESS ENABLE: When this bit is set, it allows the PC 
Registers to be accessed by the local microcontroller. The address space is 
specified by Bit 2. When this bit is reset, Addresses 40H-47H and 60H-67H are 
available for external system use. 
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5.40 Register 77H: Formatter Mode Selection Register (Read/Write) (cont.) 


Bit 2 R/AW PC REGISTER FILE DECODE SELECT: When this bit is set (and Bit 1 is set), 
the PC Register File Address is 40H-47H. (Addresses 60H-67H are available 
for external system use.) When this bit is reset (and Bit 1 is set), the PC Reg- 
ister File Address is 6(0H-67H. (Addresses 40H-47H are available for external 
system use.) 


Bit 3 R/W LOCAL INTERRUPT ENABLE: When this bit is set to a logical 1, it enables 
local interrupt capability. The individual sources of interrupt can still be disabled 
by the Interrupt Enable Registers (Registers 51H and 7EH). 


Bit 4 RAW LOCAL INTERRUPT PIN PULL-UP DISABLE: When set, this bit disables the 
pull-up on the output pin, leaving an open-drain output. This is intended to sup- 
port multiple-interrupt sources. 


Bit 5 R/iW PROGRAMMED CONTROL INDEX: When this bit is set, it simulates an active 
index condition. This bit can be used in place of INDEX (Pin 32/81). 


Bit 6 R/W SEQUENCER OUTPUT ENABLE: When set, this bit activates the output en- 
able of the Sequencer Input/Output Pin to configure it as an output. The value 
actually driven will be specified by the Current Sequencer Word Control Field, 
Bit 2. 


Bit 7 RAW HARD/SOFT* SECTOR MODE CONTROL: When reset, this bit selects the 
Soft Sector Mode. When set, this bit selects the Hard Sector Mode. The Soft 
Sector Mode selects the WAM*/AMD* functionality on the WAM*/AMD*/SEC- 
TOR (Pin 33/82). Note that the sector circuity, Sector Past (Register 7AH, Bit 
1), and sector branch conditions, are now passed to the Address Mark Detect 
Signal. The Hard Sector Mode selects the sector functionality on the WAM*/ 
AMD*/ SECTOR (Pin 33/82). Note that the sector circuitry, Sector Past (Reg- 
ister 7AH, Bit 1), and Sector Branch Conditions, are now passed to the Sector 
Signal. 


5.41 Register 78H: Branch Address Register (Write Only) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bits4-0 W BRANCH ADDRESS: Writing Bits 4-0 will cause the sequencer RAM to jump 
to this address when a branch condition is programmed and met. 
Bits 7-5 — Reserved. 
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5.42 Register 79H: Formatter Status Register (Read Only) 


This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bit 0 


Bit 1 


Bit 2 


Bit 3 


Bit 4 


Bit 5 


Bit 6 


Bit 7 
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COMPARE EQUAL: This bit is set when the result of the compare operation is 
equal. The comparison is done between the Read Data and either the Buffer 
Memory Data or the WCS Data Field, on all bytes where comparison was en- 
abled in the Compare Enabie Bit (Bit 1) of the WCS Control Field. Compare 
Equal is not valid until the Sequencer is in the ECC field. 


ID CRC ERROR: After the last bit of CRC data is read for the ID field, this bit 
will be set if all bits in the CRC are not zero. The reset conditions for this bit are: 
Register 71H, Bit 5; a write to Register 79H, and the beginning of new read/ 
write. 


ECC ERROR: This bit will be set after the last ECC Data Bit is read if there is 
a non-zero ECC syndrome indicating a data error. It will be reset when the next 
sequencer read/write is started. The reset conditions for this bit are: Register 
71H, Bit 5; a write to Register 79H, and on the beginning of a new read/write. 


UNCORRECTABLE ERROR FOUND: This bit is set when an uncorrectable 
error is found after an on-the-fly hardware correction process. (Register 71H, 
Bit 0, must be set, i.e., Hardware Correction is enabled). If Hardware Correc- 
tion is disabled (Register 71H, Bit 0 is reset), then this bit is set following a read 
of the last ECC Data Bit, when there is a non-zero ECC syndrome. The reset 
conditions for this bit are: Register 71H, Bit 5, a write to Register 79H, the load 
of the Correction Register, and a host-issued auto-command (AT Mode only) if 
the Hardware Correction Enable Bit (Register 71H, Bit 0) is set. If the Hardware 
Correction Enable Bit (Register 71H, Bit 0) is reset, this bit is reset when Reg- 
ister 71H, Bit 5, is set and following a write to Register 79H. 


CORRECTION DONE: This bit is set when a correctable error has been found 
and the read/write modification to correct the data in the buffer has been com- 
pleted. The reset conditions for this bit are: Register 71H, Bit 5, the load of the 
Correction Register and a write to Register 72H. 


SEQUENCER STOPPED: When this bit is set, it indicates that the sequencer 
is stopped, i.e., the Sequencer RAM is at Address 1FH. The ECC contents 
have not been reset, and the RG (Pin 35/84) and WG (Pin 36/85) Signals are 
reset. This bit is reset by assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


BRANCH ACTIVE: This bit is set whenever a branch condition is met. This bit 
will be reset after a read of this register. 


DATA TRANSFER STATUS: This bit indicates the status of the Data Transfer 
Bit (WCS Control Field, Bit 0). It is set wnenever data is being transferred be- 
tween the buffer memory and the disk, regardless of the state of the Suppress 
Transfer Bit (Register 7AH, Bit 5). It is reset wnen the Sequencer stops. 
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5.43 Register 79H: Sequencer Start Register (Write Only) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bits 4-0 WwW START ADDRESS: A write to this register will start the Sequencer at the 
latched address. 


Bits 7-5 _ Reserved. 


5.44 Register 7AH: Operation Control Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83) or Register 71H, Bit 5. 


Bit 0 R INDEX PAST: The index pulse from the device has been leading-edge-detect- 
ed since the last time this register was read. Reading of this bit will reset the bit 
even while the index pulse is present. (Read only). 


Bit 1 R SECTOR PAST: The sector pulse has been leading-edge-detected from the 
device since the last read of this register. Reading of this bit will reset the bit 
even while the sector pulse is present. In a Soft Sector Mode configuration, the 
Address Mark Signal should be at least one byte wide to detect an edge. (Read 


only). 
Bit 2 R AUTO-COMMAND STATUS: (PC AT Mode only) This bit is set when an auto- 


command is received and the PC R/W* Transfer Direction (Register 53H, Bit 3) 
is deasserted. This bit is reset when a write to Register 73H is issued to unlock 
the Buffer Manager Registers, and for transfers between the Formatter and the 
buffer sections. 


Bit 3 R SYNC DETECT: This bit is set during a Disk Read Operation when the internal 
serializer/deserializer has been synchronized with the incoming NRZ data, and 
the data matches the preprogrammed sync character in Register 7CH. This bit 
is cleared on the falling (trailing) edge of the RG Signal (Pin 35/84). (Read 


only). 
Bit 4 R WCS BYTE READY: When this bit is set, it indicates that a scheduled WCS 


access is completed and that another scheduled WCS access may be started. 


Bit 5 RAW SUPPRESS TRANSFER: When this bit is set, serialized or deserialized data 
will not be read or written to the buffer (disabling the buffer access mechanism 
of data transfer — Current Sequencer Word Control Field, Bit 0). During a Write 
Operation, the NRZ data that is output will consist of the contents of the WCS 
Data Field. During RG, the incoming data will be compared with the contents 
of the WCS Data Field, ECC will be verified, but no data will be transferred to 
the buffer memory. 
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5.44 Register 7AH: Operation Control Register (Read/Write) (cont.) 


Bit 6 RWW SCHEDULED WCS ACCESS/ ENABLE: When this bit is set, the microcontrol- 
ler uses the WCS Byte Ready Bit (Register 7AH, Bit 4) to access the WCS cor- 
rectly. 

Bit 7 RAW INHIBIT DATA FIELD CARRY: When this bit is set, the carry/load of the WCS 


Count Field for the data transfer will be inhibited. Also, the Sector Size Counter 
will be reinitialized from the Sector Size Register (Register 4EH); this feature is 
used for large data fields. This bit is reset by the assertion of RST* (Pin 34/83) 
or Register 71H, Bit 5. 


5.45 Register 7BH: WAM Control Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 RW WRITE ADDRESS MARK CONTROL: In Soft Sector Mode, the WAM*/AMD* 
Signal (Pin 33/82) will be asserted low for each bit-cell time corresponding to 
the bits set in this register during a Write Address Mark Operation. Output at 
the WAM*/AMD*/SECTOR Signal (Pin 33/82) is shifted two bits toward the 
MSB at the output. In Hard Sector Mode, the pin will not be asserted. 


5.46 Register 7CH: AMD Control Register (Read/Write) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 7-0 RW ADDRESS MARK DETECT CONTROL: (Synchronization Byte Pattern) This 
register is to be compared with NRZ read data when the RG Signal (Pin 35/84) 
and, if in Soft Sector Mode, the WAM*/AMD*/SECTOR Signal (Pin 33/82) are 
asserted. A match between this register and the serial NRZ read data input will 
set the SYNC Detect Bit (Register 7AH, Bit 3), and will cause the bit ring to start 
at zero and NRZ read data to be gated into the ECC. Only those bits in this reg- 
ister which are enabled by the Clock Control (Register 7FH) will be used for 
comparison. This register is reset when the RST* (Pin 34/83) is asserted. 


5.47 Register 7DH: Formatter Interrupt Status Register (Read Only) 


This register is reset by the assertion of RST* (Pin 34/83), Register 71H, Bit 5, or a microcontroller read 
of this register. 


Bit 0 R INDEX PAST: This performs the same function as Register 7AH, Bit 0. 


Bit 1 R SECTOR PAST: This performs the same function as Register 7AH, Bit 1. 
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5.47 Register 7DH: Formatter Interrupt Status Register (Read Only) (cont.) 


Bit 2 


Bit 3 


Bit 4 


Bit 5 


Bit 6 


Bit 7 


R 


INPUT DETECTED: This bit will be set by the rising edge of the Input1/Output 
Signal (Pin 31/80). This bit will be cleared by the microcontroller reading this 
register. 


SEQUENCER STOPPED: This performs the same function as Register 79H, 
Bit 5. 


ECC ERROR/UNCORRECTABLE ERROR: If the Hardware Correction En- 
able Bit is set (Register 71H, Bit 0), this bit performs the same function as Reg- 
ister 79H, Bit 3. If the Hardware Correction Enable Bit is reset, this bit performs 
the same function as Register 79H, Bit 2. 


DATA TRANSFER STATUS: This bit will be set by the rising (leading) edge of 
the Data Transfer Status Bit (Register 79H, Bit 7). 


SEQUENCER OUTPUT DETECTED: This bit will be set by the rising (leading) 
edge of the Output Signal (Pin 31/80). 


Not used; status indeterminate. 


5.48 Register 7EH: Formatter Interrupt Enable Register (Read/Write) 


This register is reset by the assertion of RST* (Pin 34/83). 


Bit 0 


Bit 1 


Bit 2 


Bit 3 


Bit 4 


Bit 5 
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R/W 


R/V 


RAW 


R/W 


R/W 


R/W 


DATA SHEET 


INDEX ENABLE: When this bit is set, it will allow the INT* Signal to be asserted 
low when the Index Past Bit (Register 7DH, Bit 0) is set. 


SECTOR ENABLE: When this bit is set, it will allow the INT* Signal to be as- 
serted low when the Sector Past Bit (Register 7DH, Bit 1) is set. 


INPUT DETECTED ENABLE: When this bit is set, it will allow the INT* Signal 
to be asserted low when the Input Detected Bit (Register 7DH, Bit 2) is set. 


SEQUENCER STOPPED ENABLE: When this bit is set, it will allow the INT* 
Signal to be asserted low when the Sequencer Stopped Bit (Register 7DH, Bit 
3) is set. 


ECC ERROR ENABLE: When this bit is set, it will allow the INT* Signal to be 
asserted low when the ECC Error/Uncorrectable Error Bit (Register 7DH, Bit 4) 
is set. 


DATA TRANSFER DETECTED ENABLE: When this bit is set, it will allow the 


INT* Signal to be asserted low when the Data Transfer Status Bit (Register 
7DH, Bit 5) is set. 
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5.48 Register 7EH: Formatter Interrupt Enable Register (Read/Write) (cont.) 


Bit 6 


Bit 7 


R/W 


SEQUENCER OUTPUT DETECTED ENABLE: When this bit is set, it will allow 
the INT* Signal to be asserted low when the Sequencer Output Detected Bit 
(Register 7DH, Bit 6) is set. 


Not used; status indeterminate. 


5.49 Register 7FH: Clock Control Register (Write Only) 
This register is reset by the assertion of RST* (Pin 34/83). 


Bits 2-0 


Bits 4-3 


Bit 5 


Bits 7-6 
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R/W 


W 
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SYNC COMPARE CONTROL: These bits specify the number of bits to be 
used in the compare for the sync byte programmed in the AMD Control Regis- 
ter (Register 7CH). 

000 = Only Bit 7 is compared 

001 = Only Bits 7 and 6 are compared 

010 = Only Bits 7, 6, and 5 are compared 

011 = Only Bits 7, 6, 5, and 4 are compared 

100 = Only Bits 7, 6, 5, 4, and 3 are compared 

101 = Only Bits 7, 6, 5, 4, 3, and 2 are compared 

110 = Only Bits 7, 6, 5, 4, 3, 2, and 1 are compared 

111 = All bits are compared 


ECC CORRECTOR CLOCK SOURCE: These two bits select the input clock 
to the ECC correction circuitry as follows: 

00 = 1FCLK/DASP* (Pin 28/77) 

01 = RRCLK (Pin 37/86) (default after RST’) 

10 = BCLK (Pin 39/88) 

11 = BCLK (Pin 39/88) divided by 2 


BUFFER CLOCK DISABLE: The user must program this bit to be reset. When 
this bit is set, the internal clock will be disabled. It is used for test purposes only. 


BUFFER CLOCK DIVIDE: These bits select the divider value that is applied to 
BCLK (Pin 39/88) to generate a buffer clock (BUFCLK) 

00 = One buffer access cycle per four BCLK cycles 

01 = One buffer access cycle per two BCLK cycles 

10 = One buffer access cycle per one BCLK cycle 

11 = One buffer access cycle per three BCLK cycles 

Bit 7 is set and Bit 6 is reset when the RST* Signal (Pin 34/83) is asserted. 
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5.50 Register 7FH: Top of Stack Register (Read Only) 


Bits 7-0 R STACK: A read of this register reads the last byte that was enabled [by the 

Stack Enable Bit (WCS Control Field, Bit 4)] onto the stack. The Address Point- 
er in ‘ring’ fashion moves around the 8-byte circular stack. As the byte is read, 
the Address Pointer moves to the previous location. The data during a read is 
never ‘popped’ from the stack; it is not lost or removed, and a continuous read 
of eight locations would bring one back around to the original location, reading 
the same data. 
If 10 bytes in a field were enabled to the stack, the last eight bytes would be 
captured, as the first two bytes would be overwritten. The first byte read from 
the stack would be the tenth byte enabled onto the stack. In reverse order, all 
of the last eight bytes could then be read continuously, in a circular manner. 
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6. SEQUENCER RAM FIELD DESCRIPTION 


The Sequencer RAM (Addresses 80H-9EH, AOH-BEH, COH-DEH, and EQH-FEH) may be written to or 
read from by the microcontroller. if the Scheduled WCS Access/WCS Access Bit (Register 7AH, Bit 6) is 
reset, then the microcontroller may access the WCS when there is no risk of the contents being accessed 
by the Sequencer. This is normally true only during data transfers or when the Sequencer is stopped. If 
the Scheduled WCS Access/WCS Access Bit (Register 7AH, Bit 6) is set, then the microcontroller may 
access the WCS in a scheduled format where there is no contention problem between microcontroller or 
Sequencer access. The Sequencer RAM is not initialized during any reset. 


6.1. Next Address Field Register Description 
6.1.1 Registers 80H-9EH Next Address Field (Read/Write) 


Bits 4-0 NEXT ADDRESS: This is the address the Sequencer will go to after the down counter has 
reached zero and a branch has not been taken. There are 31 possible Next Address loca- 
tions (OOH-1EH). The stopped condition is established by Address 1FH. 


Bits 7-5 BRANCH COMMAND: All branch commands are evaluated at the end of execution of the 
Current Sequencer Word. 


NOTE: The branch address can be the Branch Address Register (78H) or the Data/Branch Field or the React 
Branch Register unless otherwise explicitly stated. 


The following are branch commands when the Alternate Branch Command Select Bit (Bit 7) of the WCS 
Control Field is reset and all of the following conditions are true: 


« The Process ECC/CRC Select Bit (Bit 6) of the WCS Count Field is set and 
* The Read Gate Signal (Pin 35/84) is asserted. 

000 = Continue — next address used 

001 = Stop on ECC error 

010 = Stop on non-equal compare 

011 = Stop on non-equal compare or ECC error 

100 = Branch on good ECC and equal compare 

101 = Branch on ECC error 

110 = Branch on non-equal compare 

111 = Branch on non-equal compare or ECC error 


Branch Commands when the Alternate Branch Command Select Bit (Bit 7) of the WCS Control Field is 
reset, and if either of the following two conditions are true: 


* The Process ECC/CRC Select Bit (Bit 6) of the Writable Control Store (WCS) Count Field is 
reset or 
* The Read Gate Signal (Pin 35/84) is deasserted. 
000 = Continue — next address used 


001 = Stop on INPUT1 (Pin 31/80) active 
010 = Stop on index or sector active 
011 = Stop on non-equal compare 
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6.1.1 Registers 80H-9EH Next Address Field (Read/Write) (cont) 


100 = 


101 = 
110 
111 = 


Branch on Synchronization Time-out when the WCS Data Transfer is 0 (WCS 
Control Field, Bit 0). 

Branch on INPUT1/OUTPUT (Pin 31/80) active. 

Branch on index or sector active. 

Branch on non-equal compare. 


The following are branch commands when the Alternate Branch Command Select Bit (Bit 7) of the WCS 
Control Field is set and all of the following conditions are true: 


« The Process ECC/CRC Select Bit (Bit 6) of the WCS Count Field is set and 
* The Read Gate Signal (Pin 35/84) is asserted. 


60 


000 = 
001 = 


010 = 


011 = 


100 = 


101 = 


110 = 
111 = 
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No Branch. 

Stop on bad CRC. 

Branch on good CRC, bad compare to retry (use the data field for the Branch 
Register). 

On good CRC, good compare, and no Defect Bit (use the next address to process 
the data field). 


Stop on good CRC, good compare, and the Defect Bit. 
Stop on bad CRC. 
Branch on good CRC, bad compare to retry (use the data field for Branch Register). 


On good CRC, good compare, and no Defect Bit (use the next address to process 
the data field). 


Branch on good CRC, good compare, and the Defect Bit using React Branch 
Register (Register 6CH) to execute the alternate routine. 

Branch on bad CRC or bad compare to retry (use the data field for Branch 
Register). 

On good CRC, good compare, and no Defect Bit (use the next address to process 
the data field). 

Stop on good CRC, good compare, and Defect Bit. 

Branch on bad CRC or bad compare to retry (use the data field for the Branch 
Register). 

On good CRC, good compare, and no Defect Bit (use the next address to process 
the data field). 


Branch on good CRC, good compare, and Defect Bit using the React Branch 
Register (Register 6CH) to execute the alternate routine. 


Stop on Sector Count Register = 0. 


Branch on the Sector Count Register not equal to zero and the End of Track Bit is 
reset. Increment the Sector Target Register and decrement the Sector Count 
Register (use the data field for the Branch Register). 


Branch on the Sector Count Register not equal to zero and the End of Track Bit set. 
Reset the Sector Target Register to zero, and decrement the Sector Count Register 
(use the data field for the Branch Register). 


Stop on the Uncorrectable ECC Error set for previous sector if the Hardware 
Correction Enable Bit (Register 71H, Bit 0) is set. 


Stop on ECC Error if the Hardware Correction Enable Bit (Register 71H, Bit 0) is 
reset. 


No Branch. 
No Branch. 
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6.1.1 Registers 80H-9EH Next Address Field (Read/Write) (cont.) 


The following are branch commands when the Alternate Branch Command Select Bit (Bit 7) of the WCS 
Control Field is set, and /f elther of the following two conditions are true: 


* The Process ECC/CRC Select Bit (Bit 6) of the Writable Control Store (WCS) Count Field is 
reset or 
« The Read Gate Signal (Pin 35/84) is deasserted. 
000 = No branch. 


001 = If the Sector Remaining Counter Register (Registers 6DH-6EH) is not equal to 
zero, freeze ECC and read the next split of data (use the Next Address Field). 


or 
Branch on Sector Remaining Counter Register = 0 (use the Branch Register 78H). 
010 = Sector Count Register = 0 use the Next Address Field. 


Branch on the Sector Count Register not equal to zero and the End of Track Bit is 
reset (use the data field for Branch Register). 


Branch on the Sector Count Register not equal to zero and the End of Track Bit set 
(use the data field for the Branch Register). 


011 = No branch. 
100 = No branch. 
101 = No branch. 
110 = Branch on INPUT2/HOSTINT* (Pin 5/54) edge detected. 
111 = No branch. 
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6.2 Count Field Register Description 


6.2.1 Registers COH-DEH Count Field (Read/Write) 


Bits 3-0 


Bit 4 


Bit 5 


Bit 6 


Bit 7 
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COUNT: These bits are always used for the initial value of the Sequencer byte counter 
when a new state is entered. The counter is decremented on Bit Ring 7. When it reaches 
zero, a new instruction word will be accessed from the Formatter WCS. 


COUNT/SECTOR TARGET: When the Data Transfer Bit of the Current Sequencer Word 
is set, this bit is a Count Bit (for an eight-bit Count Field). When the Data Transfer Bit of 
the Current Sequencer Word is reset, this bit indicates that the Sector Target Register 
should be used as the source of comparison with the incoming NRZ data in the Sector ID 
Byte to verify the correct sector target. 


COUNT/START SYNCHRONIZATION TIMER/TWO INDEX TIMER ARM: When the Data 
Transfer Bit of the Current Sequencer Word is set, this is a Count Bit (for an 8-bit Count 
Field). 


START SYNCHRONIZATION TIMER: When this mode is selected, this bit resets and 
starts the Synchronization Timer. This counter is used to limit the amount of time that For- 
mat Sequencer will wait for synchronization with the NRZ Read Data. The Synchronization 
Byte Count Limit (Register 76H) holds a limit for the counter. If the count limit is exhausted, 
the current Read Operation will be aborted (the Format Sequencer stopped) and the Syn- 
chronization Time-out Error Bit (Register 4FH, Bit 0) will be set. This mode is selected 
when the Read Gate On Bit (Bits 6-5 of WCS Control Field) is set. 


THE TWO INDEX TIMER: This mode is selected when the Data Transfer Bit (WCS Contro! 
Field, Bit 0), and the Read Gate On Bit (WCS Control Field, Bit 6) are reset, and this bit is 
set. If Two Index pulses are detected after this circuit has been started, then the Format 
Sequencer will be stopped. 


COUNT/PROCESS ECC/CRC SELECT: When the Data Transfer Bit of the Current Se- 
quencer Word is set, this bit is a Count Bit (for an eight-bit Count Field). If, in the Current 
Sequencer Word, either the Read Gate On, or Write Gate On Bits are active, and the Data 
Transfer Bit is off, then this bit selects the CRC function. With this function active, setting 
this bit initializes the ECC function to the CRC polynomial; when this bit is cleared, the 
ECC function is initialized to the 88-bit ECC polynomial. 


When the Data Transfer Bit is off, and the Read Gate On, and Write Gate On Bits (WCS 
Control Field, Bits 6-5) are reset, this bit treats the incoming NRZ data (if Read Gate is 
active), or the outgoing NRZ data (if Write Gate is active) as an ECC field. 


COUNT/PROCESS AM/EXTENDED COUNT ENABLE: When the Data Transfer Bit of 
the Current Sequencer Word is set, this is a Count Bit (for an 8-bit Count Field). When the 
Data Transfer Bit is off, and Read Gate or Write Gate is active, this bit will set the AM active 
latch internally to define the address mark at the beginning of the ID or data field. When 
the Data Transfer Bit is off, and the Read Gate or Write Gate are reset, this register be- 
comes a 7-bit Count Field. The counter is decremented on Bit Ring 7. When it reaches 
zero, a new instruction word will be accessed from the Formatter WCS. 
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6.3 Data Field Register Description 
6.3.1 Registers EQH-FEH Data Field (Read/Write) 
Bits 7-0 DATA: This register is the source for all overhead bytes of data used by the device during 


Write Operations. During Read Operations, it is one of the operands to the comparison 
logic. When the Data Transfer Bit is on with the Write Gate asserted, the source for write 
data will be the external buffer. When Suppress Transfer is on with the Write Gate, the 
source for write data will be the content of this register. This register can also be the 
Branch Address source. 


6.4 Control Field Register Description 
6.4.1 Registers AOH-BEH Control Field (Read/Write) 


Bit 0 DATA TRANSFER: When this bit is set, the Count Field is used as an 8-bit counter. Each 
byte time that this bit is set, a byte of data will be accessed from the buffer if the Suppress 
Transfer Bit (Register 7AH, Bit 5) is reset. If Write Gate is active, then a byte of data is read 
from the buffer (if Suppress Transfer is reset) or from the Data Field (if Suppress Transfer 
is set); it is then serialized and sent to the NRZ Pin. During format, the ID field bytes can 
be written from the buffer instead of coming from the WCS Data Field (where they must 
be updated by the local microcontroller). This is accomplished by setting the Data Trans- 
fer Bit in the WCS Control Field. This will override the Suppress Transfer function for the 
ID field only. If Read Gate is active, then a byte of data is deserialized from the NRZ Pin 
and is written to the buffer (if Suppress Transfer is reset). 


Bit 1 COMPARE ENABLE: When this bit is set and the RG Signal (Pin 35/84) is asserted, it will 
allow a comparison between Read Data and the WCS Data Field. 


Bit 2 OUTPUT: This bit drives the Input/Output Signal (Pin 31/80) and is used to synchronize 
external logic functions to the state of the WCS. 


Bit 3 PROCESS SPLIT/FLAG: If the Advanced Multisector/Multisector* Bit (Bit 0 of Register 
4FH) is reset, this bit is used to indicate split or consecutive data field. If the Advanced Mul- 
tisector/Multisector* Bit (Register 4FH, Bit 0) is set, this bit is used to specify the Flag/LS 
Split Count in the ID field. 


Bit 4 STACK ENABLE: When active, read data is pushed on the 8-byte recirculating stack. 
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6.4 Control Field Register Description (cont) 


6.4.1 Registers AQH-BEH Control Field (Read/Write) 


Bits 6-5 CONTROL FIELD: Bits 6-5 are encoded as follows: 


Encoded Control Field Bits 6-5 
Bit 6 BitS5 Coded As 
0 0 No Change 


0 1 Write Gate On 


1 0 Read Gate On 


Write Gate Off 


as 
rare 


Description 

The state of the Write Gate Signal (Pin 36/85) and the Read Gate 
Signal (Pin 35/84) is not affected. 

This code is used to assert the Write Gate Signal (Pin 36/85). The 
Write Gate Signal (Pin 36/85) is asserted during the first count of 
execution of the Format Sequencer Word with this bit combination 
set. The Write Gate Signal (Pin 36/85) is not asserted if the Read 
Gate Signal (Pin 35/84) is already asserted when this bit combina- 
tion is executed. 

This code is used to assert the Read Gate Signal (Pin 35/84). The 
Read Gate Signal is asserted during the first count of the execution 
of the Format Sequencer Word with this bit combination set. The 
Read Gate Signal (Pin 35/84) is not asserted if the Write Gate Sig- 
nal (Pin 36/85) is already asserted. The Read Gate Signal is deas- 
serted at the end of ECC processing, or when the Format Sequenc- 
er goes to the stopped state. 

This code is used to deassert the Write Gate Signal (Pin 36/85). 
The Write Gate Signal (Pin 36/85) is cleared during the last count 
of the execution of the Format Sequencer Word with this bit combi- 
nation set. The Write Gate Signal (Pin 36/85) is also deasserted 
when the Format Sequencer comes to a stopped state. 


Bit 7 ALTERNATE BRANCH COMMAND SELECT: When this bit is set, the branch conditions 
in the Next Address Field are redefined, as described in Section 6.1.1. 
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6.5 WCS Worksheet 


Microprocessor Register Addresses 


Branch Next Data/ 
Sequencer Address Address Control Count Branch 
Address (Reg. 78H) Fleid Fleld Field Fleld Comments 


'o) 


HE. aU 
got >| 0! co MO Ho, BoA) =! 


ulelne) 


\ 


ioe! 
yon 


toy 
= 


1 
va te 
Vat 


alo 
a 


hyp tay 
SO WIN D 


1 I 
Diolw 


m 
mH, 


DATA XFER BITS 3-0 = CNT BITS 7-0 = DATA/ 


BITS 4-0 = NEXT 0 = 
"ADDRESS 1 = COMPEN 4 = CNT/SEC TARGET BRANCH 
2 = OUTPUT 5 = CNT/TWO INDEX ADDR 
BITS 7-5 3 = PROCESS SPLIT/ TIMERARM/SYNG 
React Address = ; FLAG TIMER 
(Reg. 6CH) ; 4 = STACKEN 6 = CNT/PROCESS 
' ECC/CRC SEL 
BITS 6,5 
0). NO CHANGE 7 = CNT/AWEXT CNT 
ALT BRANCH =0 4 01 = WRT GATE ON 
Fecal aaa 10 = READ GATE ON 


IF (RG x ECC) = 1 
000.= CONTINUE, NEXT ADDRESS USED 


11 = WRT GATE OFF 


7 
' 7 = ALTBRANCH SELECT 
‘4 
‘ 


‘ 
' ‘ 
‘ ee pa Jose eee ae eS one 
} 001= STOP ON ECC ERROR ‘ __ ~~ SIF (RG x ECC) = 0 ; 
1010= STOP ON COMPARISON NOTEQUAL # 4000= CONTINUE, NEXT ADDRESS USED f 
' 011 = STOP ON COMPARISON NOT EQUAL 1001= STOP ON INPUT1 (PIN 31/80) HIGH ' 
' OR ECC ERROR ; $010= STOP ON INDEX OR SECTOR RISING (LEADING) EDGE DETECTED 1 
; 100= BRANCH ON GOOD ECC AND ‘ ; 011 = STOP ON COMPARISON NOT EQUAL ' 
1 COMPARISON EQUAL t ; 100= BRANCH ON SYNCHRONIZATION TIMEOUT WHEN WCS DATA : 
1 101= BRANCH ON ECC ERROR ‘ t TRANSFER BIT IS RESET 1 
1 110= BRANCH ON COMPARISON NOT EQUAL ¢ 1101= BRANCH ON INPUT1 (PIN 31/80) HIGH 1 
! 111 = BRANCH ON COMPARISON NOT EQuat ! 11410= BRANCH ON INDEX OR SECTOR RISING (LEADING) EDGE DETECTED) 
; OR ECC ERROR 3 fant = BRANCH ON COMPARISON NOT EQUAL Anns ft 
NEXT PAGE FOR ALT BRANCH = 1 
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WCS Worksheet (cont) 


ALT BRANCH = 1 
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IF (RG x ECC) x1 ‘ | IF (RG x ECC) = 0 t 
000 = CONTINUE, NEXT ADDRESS USED } | 000= CONTINUE, NEXT ADDRESS USED ' 
001 = STOP ON CRC ERROR; BRANCH (DATA FIELD) ON GOOD CRC, i 4 001= IF SECTOR REMAINING COUNTER (REG 6DH & 6EH) IS NOT ZERO, 
BAD COMPARE; GOOD COMPARE & CRC, NO DEFECT BITUSE , 1 FREEZE ECC, USE NEXT ADDRESS; IF SECTOR REMAINING ' 
NEXT ADDRESS; STOP ON GOOD COMPARE & CRC AND i! COUNTER IS ZERO, BRANCH (REG 78H) ' 
DEFECT BIT 1 '010= ON SECTOR COUNT (REG 6BH) EQUAL TO ZERO USE NEXT ‘ 
010= STOP ON CRC ERROR; BRANCH (DATA FIELD) ON GOOD CRC, ! ‘ ADDRESS; BRANCH (DATA FIELD) ON SECTOR COUNT NOT ZERO | 
BAD COMPARE; GOOD COMPARE & CRC, NO DEFECT BITUSE ? , AND END OF TRACK FLAG NOT SET, ' 
NEXT ADDRESS; BRANCH (DATA FIELD)ON GOOD COMPARE ‘ INCREMENT SECTOR TARGET (REG 6AH) & 
AND CAC ANDDEFECT BIT USING REACT BRANCH (REG6CH) , 1 DECREMENT SECTOR COUNT; BRANCH (DATA FIELD) ON i 
011 = STOP ON GOOD CRC & COMPARE WITH DEFECTBIT:;GOOD  , ! SECTOR COUNT NOT ZERO & END OF TRACK FLAG SET, RESET , 
COMPARE & CRC, NO DEFECT BIT USE NEXT ADDRESS; i! SECTOR TARGET TO ZEROAND DECREMENT SECTORCOUNT | 
BRANCH (DATA FIELD) ON BAD CRC OR BAD COMPARE ‘ } 011 = CONTINUE, NEXT ADDRESS USED ‘ 
100= GOOD COMPARE & CRC, NO DEFECT BIT USE NEXT ADDRESS;! , 100= CONTINUE, NEXT ADDRESS USED ' 
BRANCH (DATA FIELD) ON BAD CRC OR BAD COMPARE; : ¢ 101= CONTINUE, NEXT ADDRESS USED ; 
BRANCH ON GOOD COMPARE & CRC AND DEFECT BIT USING , ¢ 110= BRANCH (DATA FIELD) ON INPUT2 (PIN 5/54) EDGE DETECTED, 
REACT BRANCH (REG 6CH) ) (4111 = CONTINUE, NEXT ADDRESS USED \ 
101= STOP ON SECTOR COUNT (REG 6BH) EQUALTO ZERO;STOP #§ 4 Le J 
ON ECC ERROR FOR PREVIOUS SECTOR IF HARDWARE 5 
CORRECTION ENABLED (REG 71H, BIT 0) IS SET; STOP ON Ecc! 
ERROR IF HARDWARE CORRECTION IS RESET, BRANCH (DATA , 
FIELD) ON SECTOR COUNT NOT ZERO & END OF TRACK FLAG , 
NOT SET, INCREMENT SECTOR TARGET (REG 6AH) AND ‘ 
DECREMENT SECTOR COUNT; BRANCH (DATA FIELD) ON ' 
SECTOR COUNT NOT ZERO AND END OF TRACK FLAG ‘ 
SET, RESET SECTOR TARGET TO ZERO AND DECREMENT , 
SECTOR COUNT ; 
110 = CONTINUE, NEXT ADDRESS USED ' 
111 = CONTINUE, NEXT ADDRESS USED fl 
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6.6 WCS Worksheet Example 
The following map shows a format (F), read (R), and write (W) example with the following assumptions: 


* Split data format, with up to two splits 

* ID field contains Sync, Cylinder High, Cylinder Low, Head, Sector, Flag/Split (four bytes), and- 
CRC (two bytes) 

* Data field contains Sync (three bytes, one for each data split), three data splits, and ECC 
bytes (11 bytes) 

* The Sequencer start address is 0 


Microprocessor Register Addresses 


6E(R},76(W), 17(F) |ED | 00 ~__—«Y-:« Evaluate CRC/Write CRC 
[ee [| 0 | Delay Past Write Splice 


Read Gate On, Sync Timer 


(go | FO | DataSync_ | Data Sync-Byte, Enable Stack/Compare, AM 
Data Transfer 
; o1 |F2{ oo | rite Gate Off for Write/Format, Delay Read 


| __ 00 _| Servo Delay, Extended Count Enable 
[| 00 ~—_—*|_: Evaluate ECC and Decision Point 
| F5 | 00 __| Write Gate OF, Stop if Sector Count Zero 
| F6 | 00 __| Write Gate On, Write PLO Field 
| F7 | 00 _|_Write Gate Off, Post ID Pad 
bes> 2 <3 


Branch Data/ 
Seq. Addr. Addr. Branch 
Addr, (Reg. 72+) Fleid Field Field Field Comments 
Co | 00 | [EO | or __| Stan; Wait for Indew'Sector,Two Index Timer_| 
capa [At | 00 | C1 | Delay [Et | 00 | DelayaferindeSecrr 
a2 | 20 | co | 4A | £2 | 00 | Write Gate On Selec! CRC, Write PLO] 
AS [__40_|-c3 | 61 | €3 | 00 | Read Gate On, Select CRG/Sync Timer, AM | 
Poa [80 [£4 | Wye | Field Sync. Enable SacCompare | 
| AS_| feces | 00 ES [ Cyttigh | Cylinder High, Enable Stack/Compare | 
o7 [a8 | ce [00 | es | cri tow | CyinderLow, Enable SicvCompare 
LAT [67 | 00 | 7 | Head | Head, Enable Stack and Compare | 
ca | 10 | £8 | Secor | Sector Target Reg., Enable Stack/Compare_] 
[co | 00 [| E9 | FlagMS Split | UpperDataSplitCountt 
Pca} oo EA | tsspitr | Lower Data Spit oum1 
AB | [| cB} 00 | EB | FlagMs Spiit2 | Upper Data SplitCount2 
[ccf oo [eC | tsSpi | LowerDataSplitCount2 
; 41 | | EvaluateCRCWriteCRC 
Delay Past Wie Spice 
| ReadGateOn,SyncTimer 
¢ 


a~lualo [=] 


Peel 
a 
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7. LOCAL MICROCONTROLLER-HOST INTERFACE 


CL-SH361 
PC XT/AT Disk Controller 


The local microcontroller interface to the host is programmed through a set of command, status, and con- 
trol registers. Many of these registers are shared for XT and AT applications. In general, these registers 
may be accessed at any time, except when noted. The interface is configured to XT or AT on power-up 
only. The host resets will not change this configuration. 


7.1. XT-Local Microcontroller interface 


The Local XT Register File has eight Command/General-Purpose and three Control/Status Registers. 
These registers may be accessed by the local microcontroller after setting the XT/AT Mode Bit to 1 (see 


the PC Mode Control Register). The registers are as follows: 


Address Read Write 

40H or 60H Command/General Byte 0 Command/General Byte 0 
41H or 61H Command/General Byte 1 Command/General Byte 1 
42H or 62H Command/General Byte 2 Command/General Byte 2 
43H or 63H Command/General Byte 3 Command/General Byte 3 
44H or 64H Command/General Byte 5 Command/General Byte 5 
45H or 65H Command/General Byte 4 Command/General Byte 4 
46H or 66H General Byte 6 General Byte 6 

47H or 67H General Byte 7 General Byte 7 

55H Mode/Status Mode/Status 

56H Drive Type Drive Type 

57H DRV/DMA/IRQ Status Not Used 


7.1.1 XT Registers 40H-47H (60H-67H): Command/General-Purpose (Read/Write) 


The Command/General-Purpose Registers allow the local microcontroller to transfer bytes between the 
host and the disk controller without going through the buffer memory. These registers are used to receive 
the six command or configuration bytes and to send sense status or command-completion status. The 
local microcontroller is locked out of these registers during transfers with the host involving these regis- 
ters. Host access to these registers is controlled by the local microcontroller through the XT Mode/Status 
Register. Ail the command/general-purpose registers are read/written by the local microcontroller. How- 
ever, for the host access, the read/write direction is controlled by the 1/O* Bit in the XT Mode/Status Reg- 
ister. These registers are not initialized on any reset. 
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7.1.2 XT Register 55H: Mode/Status (Read/Write) 


The Mode/Status Register contains control and status for the XT interface. All transfers between the host 
and the Local Register File are conirolied by this register. In addition, the local microcontroller may set or 
reset the state of the XT interface through this register. This register is reset by the assertion of HRST*/ 
HRST (Pin 53/2), RST* (Pin 34/83), or a host-programmed reset. The register contains the following bits: 


Bits 2-0 


Bit 3 


Bit 4 


Bit 5 


Bit 6 


Bit 7 
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R/W 


RW 


R/W 


R/W 


RAW 


LRTCO:2: The Local Register Transfer Count (LRTC) Bits set the number of 
bytes to be transferred between the host and the Loca! Register File. Up to 
eight bytes may be transferred each time. These bits contain the transfer length 
minus one (i.e., LRTC0:2 = 0 for transfer of 1). The Local Register File Transfer 
Address Pointer always starts with Register 0 and is incremented on each byte 
transfer. A read of these bits represents the number of bytes to be transferred. 


LRTRNS: The Local Register File Transfer Request (LRTRNS) Bit generates 
a transfer between the host and the register file when set to 1 by the local mi- 
crocontroller. This bit will be reset when the host transfer is complete. The local 
microcontroller should not access the Local Register File, Registers 0-7, when 
this bit is set. This bit may be set only when there are no active transfers be- 
tween the host and buffer memory (i.e., when the BTRNS Bit [Bit 4] = 0). 


BTRNS: The Buffer Transfer (BTRNS) Bit represents the state of host buffer 
memory access. When this bit is set, it indicates that transfers are active be- 
tween the host and buffer memory. When set, the local microcontroller may not 
transfer bytes between the Local Register File and the host. 


1/O*: This bit determines the direction of transfer being requested when BTRNS 
or LRTRNS is asserted (see Table 7—1 on the following page). 


C/D*: This bit determines the type of information being requested — command 
or data (see Table 7—1 on the following page). 


BUSY: The Busy Bit indicates that the controller is busy executing a command. 
The Busy Bit is set during the selection phase by the host; it is reset at the end 
of the command during the Status Phase, when the host reads the Status Byte. 
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Table 7-1. PC/XT I/O Bus Phases Table 
BUSY C/D* vO* State of Controller Direction of Transfer 


0 x X Idle 

1 0 0 Data Phase PC to Controller 
1 0 1 Data Phase Controller to PC 
1 1 0 Command Phase PC to Controller 
1 1 1 Status Phase Controller to PC 


NOTE: X = Don't care. 
7.1.3 XT Register 56H: Drive Type (Read/Write) 


The Drive Type Register is read/write and may be accessed by the local microcontroller at any time. Gen- 
erally, this register contains information required by the XT BIOS driver to configure the physical attributes 
of the drive (i.e., cylinders, heads, sectors/track). From the host, this register appears as a read-only reg- 
ister. This register is not affected by any reset. In PC/XT Master/Slave Mode, only four bits of this register 
are driven to the host. For the master, Bits 3-0 are driven. For the slave, Bits 7-4 are driven. If the CL- 
$H361 is not configured for Master/Slave Mode, then all eight bits of this register are driven to the host. 
This register is not affected by any reset. 


7.1.4 XT Reglster 57H: DRV/DMA/IRQ (Read Only) 


The DRV/MA/IRQ Status Register reflects the state of the DRV/DMA/IRQ Enable Register written to by 
the host. This read-only register can be accessed at any time. This register is reset when the HRST*/ 
HRST (Pin 53/2) is asserted or under a host program reset. 


Bit 0 R DMAEN: The DMA Request Enable Bit allows driving of the host DREQ Signal 
during Data Mode transfers. 


Bit 1 R IRQEN: The interrupt Enable Bit controls the enabie for the tri-stated host sig- 
nal HINT/HINT*. When the Interrupt Enable Bit is reset, no interrupts will be is- 
sued to the host processor. When set, this allows the controller to interrupt the 
host at the command completion phase. 


Bit 2 R DRV: In Master/Slave Mode, this bit enables the host to select a controller prior 
to issuing a command. If not in Master/Slave Mode, this bit is a don’t care. 


Bits 7-3 —_— Not Used. 
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7.2 AT Local Microcontroller Interface 


The Local AT Register File has eight Command and three Control/Status Registers. These registers may 
be accessed by the local microcontroller after setting the XT/AT Mode Bit to 0 (see the PC Mode Control 
Register). These registers are not initialized on any reset, except the Drive/Head Register. The registers 


are: 


Address Read Write 

40H or 60H Error Status Error Status 
41H or 61H Features Features 

42H or 62H Sector Count Sector Count 
43H or 63H Sector Number Sector Number 
44H or 64H Cylinder High Cylinder High 
45H or 65H Cylinder Low Cylinder Low 
46H or 66H Drive/Head Number Drive/Head Number 
47H or 67H Command Command 

55H Control/Status Control/Status 
56H Drive 0 Status Drive 0 Status 
57H Drive 1 Status Drive 1 Status 


7.2.1 AT Register 40H (60H): Error Status Register (Read/Write) 


The Error Status Register contains detailed error status of the last command failure. This register is also 
used to set controller diagnostic errors during the diagnostic command or on power-up. When an error 
occurs, this register is loaded and the Error Bit is set in the Control/Status Register. The Error Bit is 
cleared whenever the host writes to the AT Command Register. 


7.2.2 AT Register 41H (61H): Features Register (Read/Write) 
This register is command-specific and may be used to enable and disable features of the interface. 
7.2.3 AT Register 42H (62H): Sector Count Register (Read/Write) 


The Sector Count Register specifies the number of sectors to be transferred during a read/write sector 
command. This register is decremented by the local microcontroller as each sector is transferred. If this 
register is loaded with 0, then 256 sectors are transferred. 
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7.2.4 AT Register 43H (63H): Sector Number Register (Read/Write) 


The Sector Number Register contains the starting sector number for the current read/write sector com- 
mand. This register is incremented by the local microcontroller as each sector is transferred between the 
host and controller. 


7.2.5 AT Register 44H (64H): Cylinder High Register (Read/Write) 


The Cylinder High Register contains the lower eight bits of the disk cylinder address. This register, in 
conjunction with the Cylinder Low Register, constitutes a 16-bit cylinder address. This register is 
incremented by the local microcontroller as each cylinder boundary is crossed. 


7.2.6 AT Register 45H (65H): Cylinder Low Register (Read/Write) 


The Cylinder Low Register contains the upper eight bits of the disk cylinder address. This register, in con- 
junction with the Cylinder High Register, constitutes a 16-bit cylinder address. If the lower cylinder over- 
flows, this register is incremented by the local microcontroller as each cylinder boundary is crossed. 


7.2.7 AT Register 46H (66H): Drive/Head Register (Read/Write) 


The Drive/Head Register contains the sector size, drive and head number. The local microcontroller in- 
crements the head address as each track boundary is crossed. This register is reset by HRST*/HRST 
(Pin 53/2), RST* (Pin 34/83), host-programmed reset, or a diagnostic command (90H). The format of the 
register is: 


DRV# Head Number 


7.2.8 AT Register 47H (67H): Command Register (Read/Write) 


The host processor issues a new command to the disk controller through this register. The controller must 
be ‘idle’ and all other registers must be set up prior to loading the Command Register. The host may abort 
the current data transfer and start a new command by writing to the Command Register when the data 
request bit is set. 
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7.2.9 AT Register 55H: Control/Status Register (Read/Write) 


This register is reset when the RST* (Pin 34/83) or HRST*/HRST (Pin 53/2) is asserted or under host 
program reset, except Bits 1, 2, and 3; these are reset by HRST*/HRST (Pin 53/2) only. 


Bit 0 


Bit 1 


Bit 2 


Bit 3 


Bit 4 


Bit 5 


Bit 6 
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R/W 


R/W 


RAW 


ERROR: The Error Bit is set when an error occurred on the last command or 
power-up diagnostics. The error code is stored in the Error Status Register. 
This Error Bit is cleared whenever the host writes to the AT Command 
Register. 


INTEN*: The Interrupt Enable (INTEN) reflects Bit 1 of the AT Host Fixed Disk 
Register. This register is a write-only host register that the local microcontroller 
can monitor. When this bit is reset, the tri-state interrupt line to the host bus is 
enabled. 


RESET: The Reset Bit reflects the status of Bit 2 of the AT Host Fixed Disk 
Register. This register is a write-only host register that the local microcontroller 
can monitor. When this bit is set, the host is issuing a programmed reset to the 
controller. This condition can be sensed by the local microcontroller through 
the PC Reset Detected Bit (Register 50H, Bit 4) being set after a local interrupt. 


HD3EN: The Head 3 Enable/Reduced Write Current (HDSEN) Bit reflects Bit 3 
of the Fixed Disk Register. This register is a write-only host register that the lo- 
cal microcontroller can monitor. When this bit is set, the controller uses the 
head 3 line on the control cable to the drive as a head-select bit and not the 
reduced write current. This condition may not be used in all controller designs, 
since this function is only present in the ST 506/412 Disk Interface. 


INT: The Interrupt Request (INT) Bit allows the local microcontroller to set an 
interrupt to the host by writing a one to this bit. The read of this bit returns the 
status of the PC interrupt line, HINT/HINT* (Pin 41/90). If interrupt is enabled, 
the controller asserts the HINT/HINT* Signal to request each sector of data 
transfer between the host and the FIFO. HINT/HINT* is deasserted at the end 
of every sector transfer except the final sector. At the end of the last sector 
transfer, HINT/HINT* remains asserted to indicate the end of a multiple-sector 
transfer, until the interrupt is serviced by the host. However, if an error occurs 
during muitiple-sector transfers, the HINT/HINT* Signal is asserted upon the 
error detection and stays asserted through the end of the last sector transfer. 


CDATA: The Corrected Data (CDATA) Bit is set whenever a sector read from 
the disk had a correctable ECC error on the previous read sector transfer. The 
CDATA Bit is cleared whenever the host writes to AT Command Register. 


BTRNS: The Buffer Transfer (BTRNS) Bit indicates the state of host buffer 
memory access. When this bit is set, it indicates that transfers are active be- 
tween the host and the buffer memory. In a disk read, this bit is reset when the 
last data is transferred to the host. In a disk write, this bit is reset when the last 
data is transferred to the buffer memory. 
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7.2.9 AT Register 55H: Control/Status Register (Read/Write) (cont.) 


Bit 7 R/IW BUSY: The Busy Bit indicates that the controller is executing a command. The 
Busy Bit is set by the host writing to the Command Register. The Busy Bit is 
automatically cleared on the last sector of a read command after the FIFO has 
been filled and DREQ is asserted. The definition of the last sector is: the only 
sector in the case of a single-sector read, the actual last sector of a multi-sector 
read if no errors, or the sector in error regardless of the sector count (a sector 
in error is indicated by the assertion of Register 55H, Bit 0). This bit is also set 
when a diagnostic command is issued, the host writes to the Command Regis- 
ter, or when RST* (Pin 34/83), HRST*/HRST (Pin 53/2), or a host-programmed 
reset is active. 


7.2.10 AT Register 56H: Drive 0 Control/Status Register (Read/Write) 


The Drive 0 Status Register contains drive-related status information that is part of the Host Control/Sta- 
tus Register when drive 0 is selected in the Drive Number Field of the Drive/Head Register. This may be 
accessed by the local microcontroller at any time. The XT/AT Mode Bit must be set to 0 for AT operation. 
This register is reset by assertion of RST* (Pin 34/83). 


Bit 0 R/AW SKCOMPO0: The Seek Complete (SKCOMP0) Bit reflects the state of the Seek 
Complete Signal from disk drive 0. When the drive is not seeking, this bit is set. 

Bit 1 RAW FAULTO: The Write/Fault (FAULTO) Bit reflects the state of the Write Fault Sig- 
nal from disk drive 0. When this bit is set, it indicates that the drive is unsafe for 
access. 

Bit 2 R/W READYO: The Ready (READY0) Bit reflects the state of the Ready Signal from 


disk drive 0. When this bit is set, the drive is present but may not be ready for 
read/write transfers. 


Bit 3 R/W RWCO: The Reduced Write Current (RWCO) Bit reflects the state of the Re- 
duced Write Current Signal from disk drive 0. When this bit is set, the current 
to the drive write heads has been reduced. 


Bit 4 R/W OVERRIDE HD3ENO: When this bit is set, the HD3EN Bit of the AT Host Fixed 


Disk Register for disk drive 0 is forced to logical 1. 
Bits 7-5 Reserved. 
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7.2.11 AT Register 57H: Drive 1 Control/Status Register (Read/Write) 


The Drive 1 Status Register contains drive-related status information that is part of the Host Control/Sta- 
tus Register when Drive 1 is selected in the Drive Number Field of the Drive/Head Register. This may be 
accessed by the local register at any time. The XT/AT Mode Bit must be set to 0 for AT operation. This 
register is reset by assertion of RST* (Pin 34/83). 


Bit 0 R/W SKCOMP1: The Seek Complete (SKCOMP'1) Bit reflects the state of the Seek 
Complete Signal from disk drive 1. When the drive is not seeking, this bit is set. 

Bit 1 RW FAULT1: The Write/Fault (FAULT1) Bit reflects the state of the Write Fault Sig- 
nal from disk drive 1. When this bit is set, it indicates that the drive is unsafe for 
access. 

Bit 2 R/W READY1: The Ready (READY ’1) Bit reflects the state of the Ready Signal from 


disk drive 1. When this bit is set, the drive is present but may not be ready for 
read/write transfers. 


Bit 3 R/W RWC1: The Reduced Write Current (RWC1) Bit reflects the state of the Re- 
duced Write Current Signal from disk drive 1. When this bit is set, the current 
to the drive write heads has been reduced. 


Bit 4 R/W OVERRIDE HD3EN1: When this bit is set, the HD3EN Bit of the AT Host Fixed 
Disk Register for disk drive 1 is forced to logical 1. 
Bits 7-5 Reserved. 
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8. PC DISK CONTROLLER INTERFACE DESCRIPTION 


8.1. XT Disk Controller Interface Description 


The CL-SH361 supports the standard XT hardware/BIOS protocol and the additional ability to daisy-chain 
two embedded drives. The XT interface between the host and the disk over the IBM XT I/O channel is 
through a combination of I/O ports and DMA data transfers. These registers can be accessed by the XT 
host when the XT/AT Select Bit (Register 58H, Bit 7) is set. There are three read ports and four write ports. 
The ports are as follows: Read/Write Data, Status, Programmed Reset, Drive Type, and DRV/DMA/IRQ 
Enable. 


DACK* HCS0* HA1 HAO 1OR* =0 Ow* =0 

0 X X X Read Data Write Data 

1 0 0 0 Read Data Write Data 

1 0 0 1 Status Program Reset 

1 0 1 0 Drive Type Select 

1 0 1 1 Not Used DRV/DMA/IRQ Enable 


NOTE: X = Don't Care. 


8.1.1 Read Data Register (Port 0 Read) 


Data transferred from the controller to the host originates from this register. Data is defined as sector 
bytes, configuration, and command-completion information. This data is transferred by either pro- 
grammed I/O or DMA. However, DMA data transfers may only occur if the controller is in the Data Mode 
(see the Status Register). 


8.1.2 Write Data Register (Port 0 Write) 


Data transferred from the host to the controller goes through this register. Data is defined as command, 
sector-byte, and configuration information. This data is transferred either by programmed I/O or DMA. 
However, DMA transfers may only occur if the controller is in the Data Mode (see the Status Register). 
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8.1.3 Status Register (Port 1 Read) 


The Status Register contains information regarding the present state of the controller. This read-only reg- 
ister contains the following bits: 


fer Toe [oe [ooo ler [en] a 
Pa [© [wna [evans esr | oo [10 reo 


Bit 0 REQ REQUEST: When this bit is set, it indicates that the controller is ready to send 
or receive a byte. The type and transfer direction of this byte depends on the 
state of the controller, as defined by the C/D* and I/O* Status Bits. The Request 
Bit is set and cleared for each byte transferred between the host and the con- 
troller. This bit is valid even if the data transfers are being done by DMA. 


Bit 1 /0* /O*: This bit determines the requested transfer direction when the REQ Bit (Bit 
0) is asserted (see Table 8~—1). 


Bit 2 C/D* C/D*: This bit determines the type of information being requested, i.e., com- 
mand, data, or status (see Table 8—1). 


Bit 3 BUSY BUSY: This bit indicates that the controller is executing a command. When this 
bit is set, no new commands are accepted until the controller goes idle by re- 
setting the Busy Bit. The Busy Bit is set during the Selection Phase and reset 
at the end of the command. 


Bit 4 DMARQ DMA REQUEST: This bit is set only during the data transfers between the host 
and the controller, i.e., C/D*= 0, and REQ =1. In addition, the controller must 
be programmed to generate DMA transfers by setting the DMAEN Bit in DMA/ 
IRQ Enable Register. This bit is the direct image of the DREQ line on the host 
bus interface. This bit is set for each byte transfer and cleared by the host bus 


signal, DACK*. 
Bit 5 INTRQ INTERRUPT REQUEST: This bit indicates that an interrupt has been issued to 


the host. This bit directly reflects the Host Bus Signal HINT/HINT* (Pin 41/90). 
This bit is set during the Command Completion Phase. During this phase, the 
Completion Status Byte is available to the host. In order for the Interrupt Re- 
quest Bit to be set, the host must set the INTEN Bit in DMA/IRQ Enable Reg- 
ister before the Command Completion Phase. The Interrupt Request Bit may 
only be cleared by the host resetting the INTEN Bit in the DMA/IRQ Enable 
Register. 


Bits 7-6 — Not used; will read 0. 
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Table 81. PC XT I/O Bus Phases 
BUSY C/D* V/O* State of Controller Direction of Transfer 


0 X X Idle 

1 0 0 Data Phase PC to Controller 
1 0 1 Data Phase Controller to PC 
1 1 0 Command Phase PC to Controller 
1 1 1 Status Phase Controller to PC 


NOTE: X = Don't care. 


8.1.4 Reset Register (Port 1 Write) 


The host may reset the controller at any time by issuing an I/O write to Port 1. This will immediately cause 
the controller to enter the idle state if the controller is busy. 


8.1.5 Drive Type Register (Port 2 Read) 


The Drive Type Register contains information used by the host to identify the drive characteristics. The 
information contained in this register is written by the local microcontroller. This read-only register is used 
by the host BIOS driver program. 


8.1.6 Controller Select Register (Port 2 Write) 


The controiler Select Register is a write-only register that starts the command process. When the control- 
ler is idle and the host processor issues a port write to this address, the controller becomes ‘busy’ and 
enters the Command Phase. Any data can be written to this register to cause the disk controller to be- 
come busy. A write to this port when the controller is busy has no effect. 
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8.1.7 DRV/DMA/RQ Enable Reg|ster (Port 3 Write) 


The DRV/DMA/IRQ Enable Register allows the host to control both DMA transfers and interrupts to the 
host; for the embedded dual-drive configuration (optional), it allows host control of the selected drive 
through the DRV Bit. This write-only register can be loaded at any time. The DMAEN Bit allows the disk 
controller to drive the host DREQ Signal during data phase transfers. The DREQ Signal is set and cleared 
on each data transfer, forming an interlocked handshake. The DMA Request Enable Bit should be en- 
abled immediately following the ‘select’ sequence and disabled at the Command Completion Phase. The 
INTEN Bit controls the enable for the tri-stated host HINT/HINT* Signal. When the INTEN Bit is reset, no 
interrupts will be issued to the host processor. When set, this allows the disk controller to interrupt the 
host at the Command Completion Phase. To reset the interrupt once it is set, the host must reset the INT- 
EN Bit. The DRV/ DMA/IRQ Enable Register Bit definition is shown below. Bits 7-3 are don't care bits, 


but it is recommended that these bits to be set to logical zero. 


INTEN | DMAEN 


NOTE: X = Don't Care. 


8.2 AT Disk Controller Interface Description 


The AT host processor communicates with the disk controller through a series of read/write registers. 
Register access is accomplished through programmed I/O or DMA (readMrite data only). These registers 
include Data, Error Status, Features, Sector Count, Sector Number, Cylinder Address, Drive/Head Num- 
ber, Controller/Drive Status, Fixed Disk, and Digital Input. All registers are eight bits, except the Read/ 
Write Data, which can be 8/16 bits. 
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Table 8-2. HCS1* Mode Disabled (Register 52H, Bit 3, is reset; Pin 46/95 is HA9) 


DREQ BUSY HCS0* HAQ9 HA2 HA1 HAO IOR* low’ 
1 1 0 0 0 0 0 Read Data Write Data 
x 0 0 0 0 0 1 Error Status Features 
X 0 0 0 0 1 0 Sector Count Sector Count 
X 0 0 0 0 1 1 Sector Number Sector Number 
Xx 0 0 0 1 0 0 Cylinder Low Cylinder Low 
x 0 0 i) 1 ty) 1 Cylinder High Cylinder High 
X 0 0 0 1 1 0 Drive/Head Number Drive/Head Number 
X 0 0 0 1 1 1 Contr./Drive Status Command 
0 1 0 0 X xX xX Contr./Drive Status Not Allowed 
xX xX 0 1 1 1 0 Alternate Status Fixed Disk 
X x 0 1 1 1 1 Digital Input Not Used 
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Table 8-3. HCS1* Mode Enabled (Register 52H, Bit 3 is set; Pin 46/95 is HCS1*) 


DREQ BUSY HCS0* HCS1* HA2 HA1 HAO —IOR* 1lOw* 
1 1 0 1 0 0 0 Read Data Write Data 
xX 0 0 1 0 0 1 Error Status Features 
x 0 0 1 0 1 0 Sector Count Sector Count 
xX 0 0 1 0 1 1 Sector Number Sector Number 
X 0 0 1 1 0 0 Cylinder Low Cylinder Low 
X 0 0 1 1 0 1 Cylinder High Cylinder High 
x 0 0 1 1 1 0 Drive/Head Number Drive/Head Number 
Xx 0 0 1 1 1 1 Contr./Drive Status Command 
0 1 0 1 X X X Contr./Drive Status Not Allowed 
X Xx 1 0 1 1 0 Alternate Status Fixed Disk 
xX X 1 0 1 1 1 Digital Input Not Used 


8.2.1 Read Data Register (Read Only) 


The Read Data Register transfers sector and ECC data from the buffer to the host. This register is 16 bits 
wide except when transferring read ECC data, when it is eight bits. The host processor may only access 
this register during data transfers when the Data Request Bit (DRQ) is set (see Controller/Drive Status 
Register). 


8.2.2. Write Data Register (Write Only) 


The Write Data Register transfers sector and ECC data from the host to the buffer. This register is 16 bits 
wide except when transferring write ECC data, when it is eight bits. The host processor may only access 
this register during data transfers when the Data Request Bit (DRQ) is set (see the Controller/Drive Status 
Register). 


8.2.3 Error Status Register (Read Only) 


The local microcontroller can write detailed error status of the last command failure to this register. This 
register is also used to set controller diagnostic errors during the diagnostic command or on power-up. 
When an error occurs, this register is loaded and the Error Bit is set in the Controller/Drive Status Register 
(see Controller/Drive Status Register). The Error Bit is cleared whenever the host writes to the Command 
Register. This register may only be read when the Busy Bit is not set (see the Controller/Drive Status Reg- 
ister). 
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8.2.4 Features Register (Write Only) 


The Features Register is command specific and may be used to enable or disable features of the inter- 
face. An example would be using the Set Features Command to enable and disable caching. This register 
was previously called the Write Precompensation Register. This register may only be written when the 
Busy Bit is not set (see the Controller/Drive Status Register). 


8.2.5 Sector Count Register (Read/Write) 


The Sector Count Register specifies the number of sectors to be transferred during a read/write sector 
command. This register is decremented by the local microcontroller as each sector is transferred. If this 
register is loaded with 0, then 256 sectors are transferred. This register may only be accessed when the 
Busy Bit is not set (see the Controller/Drive Status Register). 


8.2.6 Sector Number Register (Read/Write) 


The Sector Number Register contains the starting sector number for the current read/write sector com- 
mand. This register is incremented by the local microcontroller as each sector is transferred between the 
host and the controller. This register may only be accessed when the Busy Bit is not set (see the Control- 
ler/Drive Status Register). 


8.2.7 Cylinder Low Reglster (Read/Write) 


The Cylinder Low Register contains the lower eight bits of the disk cylinder address. This register, in con- 
junction with the Cylinder High Register, constitutes a 16-bit cylinder address. This register may only be 
accessed when the Busy Bit is not set (see the Controller/Drive Status Register). 


8.2.8 Cylinder High Register (Read/Write) 


The Cylinder High Register contains the upper eight bits of the disk cylinder address. This register, in con- 
junction with the Cylinder Low Register, constitutes a 16-bit cylinder address. This register may only be 
accessed when the Busy Bit is not set (see the Controller/Drive Status Register). 


8.2.9 Drive/Head Register (Read/Write) 


The Drive/Head Register contains the sector size, drive and head number. This register may only be ac- 
cessed when the Busy Bit is not set (see the Controller/Drive Status Register). 


Tar] ee [ es [oe [oo le [o [a 


Bit 7, the Extension Bit, is used to extend the data field by up to 11 bytes when using ECC codes. CRC 
is not appended to data field when EXT = 1; the data field becomes ‘sector size + ECC’ bytes long. This 
register is reset when RST* (Pin 34/83) or HRST*/HRST (Pin 53/2) is asserted. It is also reset when an 
AT host sets Fixed Disk Register, Bit 2 or when the Diagnostic Command is issued by the host. 
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8.2.10 Controller/Drive Status Register (Read Only) 
The Controller/Drive Status Register specifies the state of the controller/drive. This register may be ac- 


cessed at any time; however, when the Busy Bit is set, no other bits in the register are valid. Also by read- 
ing this register, any pending interrupts to the host are cleared. 


jee7 | exe | evs | ous | oro | ore | oes | ono | 
BUSY | READY | FAULT SKCOMPL| DREQ CDATA | INDEX | ERROR 


Bit 0 ERROR ERROR BIT: This is set when an error occurred on the last command or power- 
up diagnostics. The Error Bit is cleared whenever the host writes to the Com- 
mand Register. The error code is stored in the Error Register. 


Bit 1 INDEX INDEX SIGNAL: This reflects the index Signal from the selected disk drive. 
This signal goes active once per revolution of the disk. This bit will not be set if 
the drive is not ready (Bit 6 is reset). 


Bit 2 CDATA CORRECTED DATA BIT: This bit is set, whenever, on the previous read sec- 
tor transfer, a sector read off the disk had a correctable ECC error. The correct- 
ed data bit is cleared whenever the host writes to the Command Register. 


Bit 3 DREQ DATA REQUEST: The Data Request Bit is set for data transfers to/from the 
sector buffer. This includes both sector and ECC data. The controller is consid- 
ered busy whenever the DREQ or Busy Bits are set. Also, when the Data Re- 
quest Bit is set, the host processor may read/write any of the registers, includ- 
ing the Command Register. 


Bit 4 SKCOMPL SEEK COMPLETE: The Seek Complete Bit reflects the state of the Seek Com- 
plete Signal from the selected disk drive. When the drive is not seeking, this bit 
is set. 

Bit 5 FAULT WRITE FAULT: The Write Fault Bit reflects the state of the Write Fault Signal 


from the selected disk drive. When this bit is set, it indicates that the drive is 
unsafe for read/write access. 


Bit 6 READY READY: The Ready Bit reflects the state of the Ready Signal from the selected 
disk drive. When this bit is set, the drive is present but may not be ready for 
read/write transfers. 


Bit 7 BUSY BUSY: When the Busy Bit is set, the controller is executing a command. Also, 
when this bit is set, the host processor may not read or write any other registers 
except the Controllér/Drive Status, Alternate Controller/Drive Status, Fixed 
Disk, or Digital Input registers. This bit is set when RST* or HRST*/HRST Pin 
is asserted. It is also set when an AT host sets Fixed Disk Register, Bit 2, or 
when the Command Register is loaded by the host. 
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8.2.11. Command Register (Write Only) 


The host processor issues a new command to the disk controller through this register. The controller must 
be idle and all other registers must be set up prior to loading the Command Register. The host may abort 
the current data transfer and start a new data command by writing to the Command Register when the 
Data Request Bit is set. 


8.2.12 Alternate Controller/Drive Status Register (Read Only) 


The Alternate Controller/Drive Status Register contains the same bit definition as the Controller/Drive 
Status Register. This register is used for systems that do not want to reset pending interrupts by reading 
the Controller/Drive Status Register. This register may be read at any time. 


8.2.13 Fixed Disk Register (Write Only) 


The Fixed Disk Register is a control register to select Head Mode, reset the controller, and enable inter- 
rupts and AT DMA Mode. The DMA Enable Bit (Bit 0) is an extra feature that the CL-SH361 supports for 
the AT that is not part of the generic AT interface. This feature allows a DMA channel to be multiplexed 
between multiple peripherals directly by the PC without local microcontroller intervention. To enable this 
feature, first the DMA Mode must be selected (Register 58H, Bit 3); second, the Enable DMA Control Bit 
through the Miscellaneous Control/Status Register (Register 52H, Bit 4) must be set. With these two con- 
trol bits set, then the Fixed Disk Register Bit 0 controls the DMA Enable of the DMA channel. The bit def- 
inition of the Fixed Disk Register is shown below; Bits 7-4 are don’t care bits, but it is recommended that 
the user program these bits to logical zero. This register is reset when HRST*/HRST (Pin 53/2) or RST* 


(Pin 34/83) is asserted. 


8.2.14 Digital Input Register (Read Only) 


| HOSEN: RESET | INTEN* | DMAEN 


The Digital Input Register is a diagnostic loopback register that contains Write Gate, Head Select 3/Re- 
duced Write Current, Head Select 2, Head Select 1, Head Seiect 0, Drive Select drive 1, and Drive Select 
drive 0. These bits reflect the state of signals on the disk control cable. The host may read this register at 
any time. When the host reads this register, only Bits 6-0 are driven; Bit 7 is tri-stated. Note that Bit 6 is 
not initialized by any host interface hard or soft reset. Bits 5-0 are reset in the same manner as the Drive/ 


Head Register. 
four Tove [ore [ore [oro [one [ons [ or 


NOTE: HiZ denotes high impedance. 
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9. ELECTRICAL SPECIFICATIONS 


9.1 Absolute Maximum Ratings 


Ambient temperature under Dias «0... ee eee eeceeceecneeseeseeeseeeseeesseeeesseetenes 0° C to 70°C 

Storage tOMPErature..........ceccccessesseccesesseseesesssssesesssssesrssecsesrssssseesessesssseeassesseess -65° C to 150° C 

Voitage on any pin with respect to QroUNd o.oo... eect cceseeeeeceeeeeeeeeeetaceereees GND -0.5 to Voc +0.5 Volts 
Power dissipation’ s.:..22.<:3cieecuitbs lee diard dasSa cane nciantiin ives ites: 0.50 Watt 

Power SUpply Voltage ..0..... ee eee eceeseenecseeeeceseeseceeseaeeaecneessetseeneneeseaeereseseeanene 7 Volts 


NOTE: Stress above those listed under Absolute Maximum Ratings may cause permanent damage to the device. 
This is a stress rating only and functional operation of the device at these or any conditions above those 
indicated in the operational sections of this specification is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device reliability. 


9.2 DC Characteristics 


Symbol Parameter MIN MAX Units Conditions 
Voc Power Supply Voltage 45 5.5 Vv Operating 

Vit Input Low Voltage -0.5 0.8 V 

Vin Input High Voltage 2.0 Voc +05 V 

Vou! Output Low Voltage 0.4 Vv lol =2mA 3 
Vor? Output Low Voltage 0.5 Vv lo. = 24 mA 
Vou Output High Voltage 3.5 V lon = -400 pA 
IL Input Leakage -10 10 uA 0 <Vin < Voc 
Cin Input Capacitance 10 pF 

Cout Output Capacitance 10 pF 


NOTES: 1) All output pins except for PC Signals. 
2) PC Outputs. 
3) lo, = 4 mA for RG and WG. 
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9.3 AC Characteristics/Timing Information 


9.3.1 Index of Timing Information 


Figure Title Page Number 
RESET ASS@PtlON TIMING ......scsscsesorsescsscssesescecensossccsnsesssenessssessecsenssoscessosessssasnssacessnseseates 87 
9-1a and 9-1b RESET Assertion TimingS.........0.0... ccc ccceeessssseseeseecscseeserseeeseeeserenseas 87 
Microprocessor Interface Timing............ sidesaséseesasecsouescssadiocetsus sbadeiaaesbubdcodesoabsocecaadas voreeeee BE 
9-2a Multiplexed Intel Register Read Timing ..............ccccessssessescesseseseseseneeees 89 
9-2b Multiplexed Motorola Register Read Timing .............. cesses eeeeeeeee 89 
9-3a Multiplexed Intel Register Write Timing..................: cscs teceserenee 91 
9-3b Multiplexed Motorola Register Write Timing ................. cece ceeseseteees 91 


94a Non-Multiplexed Register Read Timing ............ 


9—4b Non-Multiplexed Register Write Timing..........000 eee cence eeeeeeee 
Register 70H AccessTiming 


9-5a and 9-5b = Register 70H ACCESS TIMing......... eee cece eeeeectecseesseaeeeeseceeeeceeeeateeeee 95 
DIiSk REAG/Wite THMING .....csccccssssessesssrasessnssssnsssacsscssessescsosssnasnssnesessaessasssnasscsossscseseacacsenens 
9-6a and 9-6b Disk Read/Write Timing 
Buffer Memory Read/Write THMING ........ssscscsesreccsecsssscssserensssasscsssssseceossssseccsenesoseascansansoes 98 
9~7a and9-7b Buffer Memory Read/Write Timing..............0.... cece ee eceseeeteceeeeeeeees 99 
HOSt-PC-ProgrammMed 1/O TIMING .......scscssessesesssssrencesssscnnsscccsscssescessssssscecstersosssassossonseas 100 
9-8 Programmed I/O, 8-/16-Bit Interface Timing ......0... eee eeeeseeete teens 101 
Host DMA 8-/16-Bit Interface Timing (Single-Transter MOE) ...........-ssssccsssssssssscceereces 102 
9-9 Host DMA 8-/16-Bit Interface Timing (Single-Transfer Mode) ............. 102 
Host DMA 8-/16-Bit Interface Timing (DEMANA MOE) ........0cssessssssssssasscensssreccersesssensnsees 103 
9-10 Host DMA 8-/16-Bit Interface Timing (Demand Mode) ................0665 103 
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Table 9-1. RESET Assertion Timing Parameters 

Symbol Parameter MIN MAX Units 

tHRPWL HRST*/HRST pulse width low 500 ns 

tHRPWH HRST*/HRST pulse width high 500 ns 

tLRPWL RST* pulse width low 10 us 


t 
HRST/HRST chica 


tHRPWH 


HRST*/HRST 


t 
RST’ LRPWL 


Figures 9—1a. and 9-1b. RESET Assertion Timings 
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Table 9-2. Microprocessor Interface Timing Parameters 


Symbol Parameter MIN MAX Units 
ta ALE Width 20 ns 
tin Address Valid to RD* 4 or Ds TI 15 ns 
tr RD* Width 60 ns 
as Address Valid to ALE 5 ns 
ay ALE U to Address invalid 5 ns 
Cs CS Valid to RD* U or Ds fT 5 ns 
Cy RD‘ foros Utocs 0 ns 
toa RD* Wor DS Tt to Read Data Valid 40 ns 
tos DS Width 60 ns 
tou RD* Tl to Read Data Invalid 0 15 ns 
tsaw RM‘ valid to DS ft 5 ns 
foaw Ds U to RAW" Invalid 5 ns 
tar AD[7:0] Valid to A[7:0] 20 ns 


NOTES: tt indicates rising edge. 4 indicates falling edge. 


DA ae ey 
68 DATA SHEET May 1992 


CL-SH361 ——— 4 
PC XT/AT Disk Controller == CIRRUS LOGIC 


ALE 
ay 
<i 
AD[7:0] Ln 


tou, 
= 
—— 
ty 


cs ; 
RAD* 
taL 
ed 


A[7:0] 


Figure 9-2a. Multiplexed Intel Register Read Timing 
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Figure 9-2b. Multiplexed Motorola Register Read Timing 
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Table 9-3. Microprocessor Interface Timing Parameters 


Symbol Parameter MIN MAX Units 
ta ALE Width 20 ns 
thy Address valid to WR* 4! or bs TT 15 ns 
ty WR* Width 50 ns 
ag Address Valid to ALE |} 5 ns 
ay ALE 1 to Address Invalid 5 ns 
Cs CS Valid to WR* J or Ds TT 5 ns 
cH wr fl orps Utocs U 0 ns 
Wps Write Data Valid to WR* ff or Ds U 20 ns 
WoH wh ft or DS 4 to Write Data Invalid 10 ns 
tps DS width 60 ns 
tsrw RM* valid to DS fT 5 ns 
tHRw ps U to RW’ invalid 5 ns 
taL AD[7:0] Valid to A[7:0] 20 ns 


NOTES: ft indicates rising edge. il indicates failing edge. 
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Figure 9-3a. Multiplexed Intel Register Write Timing 
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Figure 9-3b. Multiplexed Motorola Register Write Timing 
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Table 9-4. Microprocessor Interface Timing Parameters 


Symbol Parameter MIN MAX Units 
te DS Pulse Width 60 ns 
tas Address Valid to DS ft 25 ns 
taH DS 4) to Address Invalid 0 ns 
CSF cs f tops ft 10 ns 
Cy ps U tocs 0 ns 
tba DS fT to Read Data Valid 40 ns 
tou ps U to Read Data Invalid 0 25 ns 
wds Write Data Valid to DS 20 ns 
wdiy Ds 4) to Write Data Invalid 10 ns 
tsaw RM* Valid to DS ft 5 ns 
fice DS to RW* Invalid 5 ns 


NOTES: tt indicates rising edge. 4 indicates falling edge. 
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Figure 9-4a. Non-Multiplexed Register Read Timing 
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Figure 9-4b. Non-Multiplexed Register Write Timing 
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Table 9-5. Register 70H Access Timing Parameters 


Symbol Parameter MIN MAX Units 
tho Rp* U orwr* U to mMoe* U or ces L 40 ns 
toa BD[7:0] In Valid to AD[7:0] Out 55 ns 
try RD* ff to AD{7:0] Invalid 50 ns 
ton RD*f or WR* TT to MOE*f or CE* ft 40 ns 
bay AD[7:0] In Valid to WE* J 55 ns 
tao AD[7:0] In Valid to CE* U 55 ns 
tap AD[7:0] In Valid to BD[7:0] Out 55 ns 
tanh: war U to wed 40 ns 
tow we? Tt to we* Tt 40 ns 
twee we* ff to BD[7:0] Out invalid 10 ns 


NOTES: tt indicates rising edge. J indicates falling edge. 
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Read Register 70H Timing 
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MOE* 
BD[7:0] 
In Valid 


AD[7:0] 
Out 


Write Register 70H Timing 


WR* 
AD[7:0] 
In Valid 


CE* 


WE* 


BD[7:0} 
Out 


Figures 9-5a. and 9-5b. Register 70H Access Timing Parameters 
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Table 9-6. Disk Read/Write Timing Parameters 


Symbol Parameter MIN MAX Units 
fARCLK/FCLK RRCLK/1FCLK Frequency 36 MHz 
t RRCLK/1FCLK Period 27.78 ns 
to RRCLK/1FCLK High/Low Time 11.11 ns 
ta = te RRCLK/1FCLK Rise and Fall Time 5 ns 
ds NRZ In Valid to RRCLK fT 10 ns 
dy RRCLK fT to NRZ In Invalid 5 ns 
ag! AMD* Valid to RRCLK TT 10 ns 
dy RRCLK TI to NRZ Out . 6 23 ns 
wy! RRCLK ff to WAM* Out 6 23 ns 


NOTES: ft indicates rising edge. 4 indicates falling edge. 


(1) These specifications are only applicable in the Soft Sector Mode. 
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Disk Write Timing 
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Figures 9-6a. and 9-6b. Disk Read/Write Timing Parameters 
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Table 9-7. Buffer Memory Read/Write Timing Parameters 


Symbol Parameter MIN MAX Units Conditions 
ta BCLK Period 25 ns 
tae BCLK Low/High Time 12 ns 
tar=taf BCLK Rise and Fall Time 5 ns 
ay BCLK U To Address Valid 80 ns 
doy we* U to Data Out Valid 20 ns 
doy WE’ ff to Data Out Invalid 5 ns 
Wy Address Valid to WE* DaccWw-WH ns 
Wu WE* ff to Address Hold 5 20 ns 
cw CE* Low Time Bacc ns 
dig Data in Valid to MOE* fT 10 ns 
diy, MOE* ff to Data In invalid 5 ns 
Bacc Buffer Access period 1 BUFCLK period ns 
Ww WE* Low Time BCLK High Time ns Divide By 1 Mode 
1.5 BCLK Period ns Divide By 2 Mode 
2 BCLK Period ns Divide By 3 Mode 
3 BCLK Period ns Divide By 4 Mode 
mw MOE* Low Time 1 BUFCLK period ns 


NOTES: tT indicates rising edge. U indicates falling edge. 
BUFCLK = NUMCYC (Programmed in Register 7FH) * BCLK. 
The total SRAM access time is a function of BUFCLK. 
The ay value is only intended for testing purposes. 


BUFFER READ 
Read Access Time = bDacc - dg (MIN). 
Minimum Output Enable = my. 


BUFFER WRITE 
Write Address Set-Up to WE* Low = bacc- Ww - WH (MAX). 
Data Set-Up to WE* High = wy - doy. 
Minimum Write Enable Pulse Width = wy. 
Write Access Time = Dacc - Wy (MAX). 
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Write Cycle 
tee 
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Read Cycle 


BCLK 
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Figures 9-7a. and 9-7b. Buffer Memory Read/Write Timing Parameters 
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Table 9-8. Host-PC-Programmed I/O Timing Parameters 


Symbol Parameter MIN MAX Units 
cs16, HCS0* Low, HA[2:0], HA9/HCS1* to |OCS16* Low 20 ns 
adrsey HCS0*, HA[2:0], HA9/HCS1* Set-up to 

tOR*/tOW* Low 30 ns 
adryip HCS0*, HA[2:0], HA9/HCS1* Hold from 

IOR*/IOW* High 10 ns 
ioch, IOR*/IOW* Low to IOCHRDY Low 25 ns 
iochtw IOCHRDY Pulse Width 0 5*BUFCLK ns 
rdTa IOR* Low to HDB[15:0] Valid 60 ns 
rduip IOR* High to HDB[15:0) invalid 5 ns 
rdrpy IOR* High to HDB[15:0] Tri-state 30 ns 
wds HDB/[15:0] Set-up to |OW* High 40 ns 
wdup HDBj[15:0] Hold from IOW* High 10 ns 
"WPULSE IOR*/IOW* Pulse Width 80 ns 


NOTE: BUFCLK is the internal Buffer Clock that indicates the period of Buffer Access Cycles derived from BCLK 
in the appropriate Divide By Mode (Register 7FH, Bits 6 and 7). The minimum Buffer Access Cycle is 
83.33 ns. 
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Figure 9-8. Programmed I/O, 8-/16-Bit Host Interface Timing 
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Table 9-9. Host DMA 8-/16-Bit interface Timing Parameters (Single-Transfer Mode) 


Symbol Parameter MIN MAX Units 
dreq, DREQ Low from DACK* Low 60 ns 
dmaset DACK* Low to IOR*/IOW* Low 10 ns 
dmapip DACK* Hold from IOR*/IOW* High 10 ns 
rdta 1OR* Low to HDB[15:0] Valid 50 ns 
rdyip IOR* High to HDB[15:0] Invalid 5 ns 
rdtri IOR* High to HDB[15:0] Tri-state 30 ns 
wds HDB/15:0] Set-up to IOW* High 20 ns 
wdytp HDB[15:0] Hold from IOW* High 10 ns 
MWPULSE IOR*/IOW* Pulse Width 80 ns 
DREQ 
dreq. 
DACK* 
loROW* ee OmaHLD 
dmagey rarer 
ie oad) AS, Sl ee, eal 
HDB[15:0] bat) ae 
(Write) K—__j__ 
wds wd 


Figure 9-9. Host DMA 8-/16-Bit Interface Timing (Single-Transfer Mode) 
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Table 9-10. Host DMA 8-/16-Bit Interface Timing Parameters (Demand Mode) 


Symbol! Parameter MIN MAX Units 
dreq, DREQ Low from IOR*/IOW* Low 60 ns 
dmaset DACK* Low to [(OR*/IOW* Low 10 ns 
dmayip DACK* Hold from IOR*/IOW* High 10 ns 
wy IOR*/IOW* High 50 ns 
rdta IOR* Low to HDB[15:0] Valid 50 ns 
dip IOR* High to HDB[15:0] Invalid 5 ns 
rdrrl IOR* High to HDB[15:0] Tri-state 30 ns 
wds HDB[15:0] Set-up to {OW* High 20 ns 
Wduip HDB[15:0] Hold from |OW* High 10 ns 
MWPULSE IOR*/IOW* Pulse Width 80 ns 

DREQ 

DACK* dreq, dmariip 


PULSE WH 


——| 
—___> 


(Read) 
ase rt, dui 
wis —_ 
wds wduip 


Figure 9-10. Host DMA 8-/16-Bit Interface Timing (Demand Mode) 
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10. SAMPLE PACKAGE 
10.1 100-Pin PQFP Package Dimensions (ElAJ) 


19.85 MIN 
20.15 MAX 


13.85 MIN 
14.15 MAX — 


CL-SH361 


10G6-Pin EIAJ PQFP 


— 16.95 MIN 
En 18.30 MAX 


22.95 MIN 


———_-_—__.--__-—__ > 
2.60 MIN 2450 MAX. 
2.80 MAX 1.60 MIN 
0.13 MIN Vv 2.10 MAX 
0.20 HAX 
Y i 0° MIN 
u 
| ry .20 MI 12° MAX 
pee 0.40 MAX 2-70 MIN 
P| « 3.15 MAX 


1.20 MAX 


NOTE: Package dimensions are in millimeters. 
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10.2 100-Pin VQFP Package Dimensions (EIAJ) 


13.90 MIN 
14.10 MAX 


wsoomm | Eee CL-SH361 = 


14.10 MAX =< 
as 100-Pin EIAJ VQFP — 
12.00 TYP “4 


== 15.56 MIN 
16.50 MAX 


WUDHU EUR UY EU Ud 
HOHE ood 
YUWURKDRBORBOHKOOHOOKDOKDOOGDaORBAABDaRBaO 
12.00 TYP, ————_—_____—_> 


15.56 MIN 


> 
16.50 MAX 


1.26 MIN 


y -54 MAX 


0.30 MIN 


0.08 MIN 0.70 MAX 
0.23 MAX 
0° MIN 
A 12° MAX 
1.40 MIN 
0.30 MIN 
> 1.80 MAX 


0.70 MAX 


NOTE: Package dimensions are in millimeters. 
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11. ORDERING INFORMATION 


CL - SH 361 - 36 QC -A 


CIRRUS LOGIC, Inc. oa 


Storage, Hard Disk Revisiont 
Part Number Temperature Range: 
Serial Data Rate: . 
36 = 36 MHz 
Package Type: 


Q = Quad Flat Pack (QFP) 


CL - SH 361 - 36 VC - 


CIRRUS LOGIC, Inc. 7 | | 
Storage, Hard Disk Revisiont 
Part Number Temperature Range: 


Serial Data Rate: theca 


36 = 36 MHz 


Package Type: 
V = Very Low-Profile Quad Flat Pack (VQFP) 


f Contact Cirrus Logic, Inc., for up-to-date intormation on revisions. 


NOTE: See Section 5.30, Register 6FH: Revision Register. 
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Direct Sales Offices 


Domestic 


N. CALIFORNIA 
San Jose 

TEL: 408/436-7110 
FAX: 408/437-8960 


S. CALIFORNIA 
Tustin 

TEL: 714/258-8303 
FAX: 714/258-8307 


Thousand Oaks 
TEL: 805/371-5381 
FAX: 805/371-5382 


ROCKY MOUNTAIN 
AREA 


SOUTH CENTRAL 
AREA 

Austin, TX 

TEL: 512/794-8490 
FAX: 512/794-8069 


Plano, TX 
TEL: 214/985-2334 
FAX: 214/964-3119 


NORTHEASTERN 
AREA 

Andover, MA 

TEL: 508/474-9300 
FAX: 508/474-9149 


SOUTH EASTERN 
AREA 

Boca Raton, FL 
TEL: 407/362-5225 
FAX: 407/994-9887 


International 


GERMANY 
Herrsching 
TEL: 49/08152-2030 
FAX: 49/08152-6211 


JAPAN 
Tokyo 
TEL: 81/3-5389-5300 


SINGAPORE 
TEL: 65/3532122 
FAX: 65/3532166 


TAIWAN 

Taipei 

TEL: 886/2-718-4533 
FAX: 886/2-718-4526 


UNITED KINGDOM 

Hertfordshire, England 
TEL: 44/0727-872424 
FAX: 44/0727-875919 


Boulder, CO FAX: 81/3-5389-5540 


TEL: 303/939-9739 
FAX: 303/440-5712 


The Company 


Cirrus Logic, Inc., produces high-integration peripheral controller circuits for mass storage, graphics, 
and data communications. Our products are used in leading-edge personal computers, engineering 
workstations, and office automation equipment. 


The Cirrus Logic formula combines proprietary S/LA™* IC design automation with system design 
expertise. The S/LA design system is a proven tool for developing high-performance logic circuits in 
half the time of most semiconductor companies. The results are better VLSI products, on-time, that 
help you win in the marketplace. 


Cirrus Logic's fabless manufacturing strategy, unique in the semiconductor industry, employs a 
full manufacturing infrastructure to ensure maximum product quality, availability and value for our 
customers. 


Talk to our systems and applications specialists; see how you can benefit from a new kind of 
semiconductor company. 


Tt U.S. Patent No. 4,293,783 © Copyright, Cirrus Logic, Inc., 1992 


Cirrus Logic, Inc., believes the information contained in this document is accurate and reliable. However, it is subject to change 
without notice. No responsibility is assumed by Cirrus Logic, Inc., for its use, nor for infringements of patents or other rights of third 
parties. This document implies no license under patents or copyrights. Trademarks in this document belong to their respective 
companies. Cirrus Logic, Inc., products are covered under one or more of the following U.S. patents: 4,293,783; Re. 31,287; 
4,763,332; 4,777,635; 4,839,896; 4,931,946; 4,979,173. 
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